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