题目描述:
时间限制:c/c++语言1000MS; 其它语言3000MS
内存限制:c/c++语言65536KB;其他语言589824KB
如下图一个类似手机屏幕的矩形区域,宽度为w,高度为h,一个小球(视为质点,忽略其体积大小)初始位于底边距离左侧x的位置,向右上角45度发射。当小球碰到边界时,按完全弹性碰撞理想反弹,如果小球恰好碰到角落,则反向返回。如此无限循环。
请编写程序,输出前n次小球回到底边时的横坐标(首次发射时的不算)。
输入:
每个输入是一行依次表示为w,h,x,n的4个正整数,且0
输出:
每个测试用例输出一行,包含n个整数,以空格隔开。
样例输入: 2 2 1 3
样例输出: 1 1 1
注意原点(我错在这里了,说多了都是泪啊)
#include
int main(){
int w,h,x,n;
cin>>w>>h>>x>>n;
int ans = 0;
for(int i = 1; i < n; ++i){
ans = 2*i*h+x;
if((ans/w)%2 == 0){
printf("%d ",ans%w);
}else{
printf("%d ",w-ans%w);
}
}
ans = 2*n*h+x;
if((ans/w)%2 == 0){
printf("%d\n",ans%w);
}else{
printf("%d\n",w-ans%w);
}
return 0;
}