CSP 201803-2 碰撞的小球 C++满分题解

2023-12-28 21:43:11

解题思路:

1.用两个数组分别存储和坐标和速度

2.碰到边界或者其它球时速度方向改变

#include<bits/stdc++.h>
using namespace std;

int main()
{
	int n,L,t;
	cin>>n>>L>>t;
	
	int res[105];  //存储坐标
	int v[105];  //存储速度
	
	for(int i=0;i<n;i++)
	{
		cin>>res[i];
		v[i]=1;
	} 
	
	while(t--)
	{
		for(int i=0;i<n;i++)
		{
			res[i]+=v[i];
		}
		
		for(int i=0;i<n;i++)
		{
			if(res[i]==0||res[i]==L)  //碰到边界 
			{
				v[i]*=(-1);
			}
			else
			{
				for(int j=0;j<n;j++)
				{
					if(res[i]==res[j])  //碰到其它小球 
					{
						v[i]*=(-1);
						v[j]*=(-1);
						break;
					}
				} 
			}
		}
	}
	
	for(int i=0;i<n;i++)  cout<<res[i]<<' ';
	
	return 0;
}

文章来源:https://blog.csdn.net/qq_73936405/article/details/135138927
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。