mirage


私信TA

用户名:mirage915

访问量:12284

签 名:

蒟蒻也想变强啊..

等  级
排  名 2336
经  验 2351
参赛次数 2
文章发表 9
年  龄 0
在职情况 在职
学  校
专  业

  自我简介:

解题思路:


化为质点忽略半径,利用对称解决反弹

注意事项:


a=a*asin(1)/90//把角度转化为弧度( 没有用这个公式因为精度问题错了两遍o(╥﹏╥)o  )


参考代码:


#include<stdio.h>
#include<math.h>
main()
{
	double L,W,R,a,v,s,x,y;
	while(~scanf("%lf%lf%lf%lf%lf%lf%lf%lf",&L,&W,&x,&y,&R,&a,&v,&s) && L!=0)//只需判断一个 L!=0 即可。 
	{
		L-=2*R;     W-=2*R;//长宽减去 2R 
		x-=R;       y-=R;// X,Y 减去 R,这样就可以把球看成质点运动。 
		x+=v*cos(a*asin(1)/90)*s;     y+=v*sin(a*asin(1)/90)*s;//速度分解为X,Y方向 * 时间 
		while(x<0 || x>L)// X 超出边界 
		{
			if(x>L) x=2*L-x;//X关于L对称 
			if(x<0) x=-x;// X 关于 0 对称 
		}
		while(y<0 || y>W)// Y 同上  
		{
			if(y>W) y=2*W-y;
			if(y<0) y=-y;
		}
		printf("%.2lf %.2lf\n",x+R,y+R);// 原坐标加回 R , 系统会自动四舍五入 
	}
 }


 

0.0分

9 人评分

  评论区

我这也有一个版本,大家看看如何
#include<stdio.h>
#include<math.h>
#define PI 3.141592
int main()
{
	double L,W,x,y,a,v,s,R,m,x1,y1;

	while(scanf("%lf %lf %lf %lf %lf %lf %lf %lf",&L,&W,&x,&y,&R,&a,&v,&s))
	{
		if(L==0) break;
		a = a * asin( 1 ) * 2 / 180;
		x1=x+v*s*cos(a);
		y1=y+v*s*sin(a);
			while(1)
		{
			if(x1>(L-R))		x1=2*(L-R)-x1;
			else if(x1<R)     x1=2*R-x1;
			if(y1>(W-R))  		y1=2*(W-R)-y1;
			else if(y1<R) 	y1=2*R-y1;
			if(R<=x1&&x1<=L-R&&R<=y1&&y1<=W-R) break;
		}
		printf("%.2lf %.2lf\n",x1,y1);
	}
	return 0;
 }
2020-01-07 16:22:48
大佬,时间超限50%了,不过感觉你的方法比其他的要好理解,非常感谢!!!!!
2019-11-12 15:00:01
思想很棒
2019-11-04 15:37:42
为什么scanf前要加个负号
2019-11-03 21:42:19
膜拜大佬
2019-10-28 17:12:33
  • «
  • 1
  • »