这题全站第一!
2023-08-27 13:13:59
发布于:广东
5阅读
0回复
0点赞
执行用时 5ms
内存消耗 0.58MB
攀比行为不可取(doge
题意
有很多个人排在一条水平直线上,他们在踢球,拿到球的会踢给离他最近的那个,如果旁边的两个人距离一样,那么他会踢给这两个人中左边的那个,问至少要多少个球,才能让每个人都踢上一遍。
思路
对每个人都进行深搜,对路径进行标记(后面搜的人能够覆盖前面搜过留下的路径),所有人搜完后,看一下一共有多少个不同的标记,标记的个数就是所需要的球的个数。
搜索时要注意端点的判断,不要走出界了。
(我的很多队友用了区间划分做 ,通过对距离的判断,能够确定球只能在哪个区间踢动,看有多少个区间就能确定需要多少个球了)
反思
这道题不难,写它不是不会,而是做题的时候把题意理解得不一样,题目中写到
(and if multiple cows are the same distance from her, she will pass the ball to the cow farthest to the left among these).
以为这个是指踢球踢给所有的牛里面最左边的那只,其实是踢给距离相等的牛中,左边的那只。
题意理解错特别伤,英语有待提高。
AC代码
#include<cstdio>
#include<cstdlib>
#include<string>
#include<vector>
#include<queue>
#include<algorithm>
#include<cmath>
using namespace std;
int a[105];//位置
int dis[105][5];//1是左,2是右
int vis[105];//标记
int ans[105];
int cnt=1;
int dfs(int i)
{
if(vis[i]==cnt)
return 0;
vis[i]=cnt;
if(dis[i][1]==0) //如果是端点,走对的那条
dfs(i+1);
else if(dis[i][2]==0)
dfs(i-1);
else if(dis[i][1]!=0&&dis[i][2]!=0)//如果不是端点,继续搜
{
if(dis[i][1]<dis[i][2])
dfs(i-1);
else if(dis[i][1]>dis[i][2])
dfs(i+1);
else//两边一样近 ,给左边
dfs(i-1);
}
return 0;
}
int main()
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
sort(a+1,a+n+1);//从左到右排
dis[1][2]=a[2]-a[1];
dis[n][1]=a[n]-a[n-1];
for(int i=2;i<n;i++){
dis[i][1]=a[i]-a[i-1];
dis[i][2]=a[i+1]-a[i];
}
for(int i=1;i<=n;i++){
if(vis[i]==0)
dfs(i);
cnt++;
}
for(int i=1;i<=n;i++)
ans[vis[i]]=1;
cnt=0;
for(int i=1;i<=105;i++)
if(ans[i]==1)
cnt++;
printf("%d\n",cnt);
return 0;
}
这里空空如也
有帮助,赞一个