小球反弹(蓝桥杯C语言)

有一长方形,长为 343720343720 单位长度,宽为 233333233333 单位长度。在其内部左上角顶点有一小球 (无视其体积),其初速度如图所示且保持运动速率不变,分解到长宽两个方向上的速率之比为 dx:dy=15:17dx:dy=15:17。小球碰到长方形的边框时会发生反弹,每次反弹的入射角与反射角相等,因此小球会改变方向且保持速率不变(如果小球刚好射向角落,则按入射方向原路返回)。从小球出发到其第一次回到左上角顶点这段时间里,小球运动的路程为多少单位长度?答案四舍五入保留两位小数。

小球反弹(蓝桥杯C语言)_第1张图片

#include 
#include 
#include 
//一个简单的计算两数公约数的函数 
long long gcd(long long a,long long b)
{
	while(b!=0)
	{
		long long temp = b;
		b = a%b;
		a = temp;
	}
	return a;
}
//主函数 
int main()
{
	//已知条件 
	long long L = 343720;
	long long W = 233333;
	int vx = 15;
	int vy = 17;
	//小球要回到原点,必定走过2L及2W的整数倍,见下图解析
	//求最大公约数(g)                                
	long long a = vy*L;
	long long b = vx*W;
	long long g = gcd(a,b);
	//水平方向最少走过m个2L 
	long long m = vx*W/g;
	//diatance=(斜边/底边)*水平方向走过距离 
	double distance = (sqrt(vx*vx+vy*vy)/vx)*(2*L*m);  
	printf("%.2f",distance);
}

小球反弹(蓝桥杯C语言)_第2张图片

你可能感兴趣的:(蓝桥杯,c语言,职场和发展)