首页 > 其他 > 详细

丢手绢

时间:2021-06-01 09:12:14      阅读:26      评论:0      收藏:0      [点我收藏+]

题目:

https://ac.nowcoder.com/acm/problem/207040

思路:
离得最远的两个小朋友离得有多远

两个小朋友的距离为沿着圆圈顺时针走或者逆时针走的最近距离

两种情况:

 

>=周长的最小距离

<=周长的最大距离

由于a到b  和  b到a是对称的,所以算一种就都算到了

#include<stdio.h>
#include<algorithm>
using namespace std;
const int maxn=1e5+7;
int main()
{
int n,d[maxn];
scanf("%d",&n);
int sum=0;
for(int i=1;i<=n;i++)
{scanf("%d",&d[i]);
sum+=d[i];
}
int r=1;
int t=0;
int ans=0;
for(int i=1;i<=n;i++)
{

//求出刚刚大于的点
while(2*t<sum)
{
t+=d[r++];
if(r==n+1)
r=1;
}
ans=max(ans,min(t,sum-t));
t-=d[i];
}
printf("%d\n",ans);
}

丢手绢

原文:https://www.cnblogs.com/aacm/p/14835495.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!