本文主要是介绍蓝桥杯:握手问题和小球反弹问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
试题 A: 握手问题
【问题描述】
【答案提交】
#include <iostream>
using namespace std;
int main() {int total_people = 50;int no_handshake_people = 7;int handshake_count = 0;for (int i = 0; i < no_handshake_people; ++i) {handshake_count += (total_people - no_handshake_people + 1);}cout << handshake_count<< endl;return 0;
}
试题 B: 小球反弹
本题总分:5 分
【问题描述】
有一长方形,长为 343720 单位长度,宽为 233333 单位长度。在其内部左 上角顶点有一小球(无视其体积),其初速度如图所示且保持运动速率不变,分 解到长宽两个方向上的速率之比为 dx : dy = 15 : 17。小球碰到长方形的边框时 会发生反弹,每次反弹的入射角与反射角相等,因此小球会改变方向且保持速 率不变(如果小球刚好射向角落,则按入射方向原路返回)。从小球出发到其第 一次回到左上角顶点这段时间里,小球运动的路程为多少单位长度?答案四舍 五入保留两位小数。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个小数,在提交答案时只填写这个小数,填写多余的内容将无法得分。
#include <iostream>
#include <cmath>
#include <iomanip>
using namespace std;
int main() {double length = 343720;double width = 233333;double dx_ratio = 15.0 / 17.0;double dy_ratio = 17.0 / 15.0;double dx = sqrt(length * length / (dx_ratio * dx_ratio + 1));double dy = dx * dy_ratio;double total_distance = 0;while (true) {total_distance += dx;if (total_distance >= length) {break;}total_distance += dy;if (total_distance >= width) {break;}}cout << fixed << setprecision(2) << total_distance << endl;return 0;
}
这篇关于蓝桥杯:握手问题和小球反弹问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!