解题思路:
将台球的整个运动过程沿水平和竖直两个方向分解,分别求出末横坐标M和末纵坐标N
参考代码:
#台球碰撞 from math import * def REAL(p,q): if p<=q: return p else: return 2*q-p while True: L,W,x,y,R,a,v,s=map(int,input().split()) S=v*s m=L-2*R n=W-2*R X=S*fabs(cos(a/180*pi)) Y=S*fabs(sin(a/180*pi)) if S==0: break elif a<=180: if a<=90: if X<=L-x: M=X+x if Y<=W-y: N=Y+y else: N=W-R-REAL((Y+y-W+R)%(n*2),n) else: M=L-R-REAL((X+x-L+R)%(2*m),m) if Y<=W-y: N=Y+y else: N=W-R-REAL((Y+y-W+R)%(n*2),n) else: if X<=x-R: M=x-X if Y<=W-y: N=Y+y else: N=W-R-REAL((Y+y-W+R)%(n*2),n) else: M=REAL((X+R-x)%(2*m),m)+R if Y=270: if X<=L-x: M=X+x if Y<=y-R: N=y-Y else: N=REAL((Y+R-y)%(2*n),n)+R else: M=L-R-REAL((X+x-L+R)%(2*m),m) if Y<=y-R: N=y-Y else: N=REAL((Y+R-y)%(2*n),n)+R else: if X<=x-R: M=x-X if Y<=y-R: N=y-Y else: N=REAL((Y+R-y)%(2*n),n)+R else: M=REAL((X+R-x)%(2*m),m)+R if Y<=y-R: N=y-Y else: N=REAL((Y+R-y)%(2*n),n)+R print("{:.2f} {:.2f}".format(M,N))
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:857 |
校门外的树 (C语言代码)浏览:702 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:531 |
1118(求助_已解决)浏览:329 |
剪刀石头布 (C++代码)浏览:1713 |
用筛法求之N内的素数。 (C语言代码)浏览:531 |
简单的a+b (C语言代码)浏览:416 |
数列有序 (C语言代码)浏览:935 |
盐水的故事 (C语言代码)浏览:1529 |
小O的乘积 (C语言代码)浏览:1014 |