解题思路:只需要关注球心的运动轨迹,分为x和y两个分量分别计算,若越界(碰撞)则翻转,用一个flag表示翻转后朝向
注意事项:默认朝向为正,而sin和cos的结果可能为负,因此需要fabs()取绝对值,数据要定义为double,float会出错
参考代码:
#include<stdio.h>
#include<math.h>
#define PI 3.14159265358979323846
int main()
{
int i=0,flagx,flagy;
double x,y,Sx,Sy,px[25],py[25],L,W,R,a,v,s;
scanf("%lf%lf%lf%lf%lf%lf%lf%lf", &L,&W,&x,&y,&R,&a,&v,&s);
while(L+W+R+x+y+a+v+s){
flagx=1,flagy=1; //默认初始朝正向
Sx=fabs(v*cos(a*PI/180)*s+x-R); //运动路径
Sy=fabs(v*sin(a*PI/180)*s+y-R);
while(Sx>(L-2*R)){ //越界判断
Sx-=(L-2*R); //越界后翻转
flagx*=-1; //设立标志位
}
while(Sy>(W-2*R)){
Sy-=(W-2*R);
flagy*=-1;
}
if(flagx==-1) //若最后运动方向为负
Sx=L-2*R-Sx;
if(flagy==-1)
Sy=W-2*R-Sy;
px[i]=Sx+R; //结果存入数组
py[i]=Sy+R;
i++;
if(i>24) //最多25组
break;
scanf("%lf%lf%lf%lf%lf%lf%lf%lf", &L,&W,&x,&y,&R,&a,&v,&s);
}
for(int j=0;j<i;j++){
printf("%.2f %.2f\n",px[j],py[j]);
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复