解题思路:

1.

将小球速度分解为x,y轴方向的分量,

vx=v*cos(a);  

vy=v*sin(a);

注意c语言函数double cos(double a),里的a是弧度,而题目输入却是角度

所以先进行角度到弧度的转换:

a2=a*acos(-1)/180;  其中acos(-1)求得的是PI的精确值;


2.

小球活动范围为x轴:0+R 到 L-R

求得小球在x轴方向移动的距离Lx=vx*s,为了方便实现步骤3,对这个移动距离做一点变换

如果Lx为正,则将它加上x0,求得相对于坐标原点的正距离:dx=Lx+x0

如果Lx为负,则求出小球相对于球桌右边界的负距离:dx=Lx+x0-(L-R);



3.易错点(我改了三次)

通过一个循环控制dx在[R,L-R]之间进行折叠,直到dx在球桌范围内

while

{

if(R<=dx&&dx<=L-R) break;

if(dx>L-R) dx=-(dx-L+R);  //小球在x轴正方向撞到右边界,折回,将dx变为负值,此时小球x坐标位置为L-R

if(dx<0)   //dx小于0有两种情况,一种撞不到左边界,一种则撞到了

{

if(dx<R-(L-R)) dx=-(dx+(L-2*R))+R;  //小球碰到左边界,折回,将dx变为正值,此时小球坐标位置为R

//值得注意的是这里变为正值之后加上R,为对应步骤2中的变换。

else dx=L-R+dx;

}

}


y轴方向同理






注意事项:





参考代码:

#include<stdio.h>

#include<math.h>

#define TRUE 1


int main()

{

double L,W,x0,y0,R,a,v,s;

double vx,vy,a1,dx,dy,Lx,Ly;

while(TRUE)

{

 

scanf("%lf%lf%lf%lf%lf%lf%lf%lf",&L,&W,&x0,&y0,&R,&a,&v,&s);

if(L==0&&W==0&&x0==0&&y0==0&&R==0&&a==0&&v==0&&s==0) break;

a1=a*acos(-1)/180;

vx=v*cos(a1);

vy=v*sin(a1);

Lx=vx*s;

Ly=vy*s;

if(Lx>=0) dx=Lx+x0;

else dx=Lx+x0-(L-R);

if(Ly>=0) dy=Ly+y0;

else dy=Ly+y0-(W-R);

// printf("%.2f %.2f %.2f %.2f\n",vx,vy,dx,dy);

while(TRUE)

{

if(R<=dx&&dx<=L-R) break;

if(dx>L-R) dx=-(dx-L+R);  //小球在x轴正方向撞到右边界,折回,将dx变为负值,此时小球x坐标位置为L-R

if(dx<0)   //dx小于0有两种情况,一种撞不到左边界,一种则撞到了

{

if(dx<R-(L-R)) dx=-(dx+(L-2*R))+R;  //小球碰到左边界,折回,将dx变为正值,此时小球坐标位置为R

//值得注意的是这里变为正值之后加上R,为对应步骤2中的变换。

else dx=L-R+dx;

}

}

while(TRUE)

{

if(R<=dy&&dy<=W-R) break;

if(dy>W-R) dy=-(dy-W+R);

if(dy<0) 

{

if(dy<R-(W-R)) dy=-(dy+(W-2*R))+R;  

else dy=W-R+dy;

}

}

printf("%.2f %.2f\n",dx,dy);

}

return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论