【问题描述】
熊大妈的奶牛在时针的带领下,围成了一个圆圈跳舞。由于没有严格的教育,奶牛们之间的间隔不一致。
奶牛想知道两只最远的奶牛到底隔了多远。奶牛A到B的距离为A顺时针走和逆时针走,到达B的较短路程。告诉你相邻两个奶牛间的距离,请你告诉奶牛两只最远的奶牛到底隔了多远。
【输入】
第一行一个整数N,表示有N只奶牛。(2≤N≤100000)
接下来2~N+1行,第I行有一个数,表示第I-1头奶牛顺时针到第I头奶牛的距离。(1≤距离≤maxlongint,距离和≤maxlongint)
第N+l行的数表示第N头奶牛顺时针到第1头奶牛的距离。
【输出】
一行,表示最大距离。
【输入样例】
5
1
2
3
4
5
【输出样例】
7
【分析】
设总距离为s。
不难看出从i到j的距离为min{dist[i][j],s-dist[i][j]};
此处我们可以破环成列,(当然,形成环形链表也是一个不错的方法)用左右两个指针维护一个区间,每次while循环右指针++,如果区间和大于s/2则左指针++。
详见代码:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
long long n,s=0;
long long a[400100];
int main()
{
freopen("circle.in","r",stdin);
freopen("circle.out","w",stdout);
ios::sync_with_stdio(false);
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i];
for(int i=1;i<=n;i++)
s+=a[i],a[i+n]=a[i];
n=n*2,a[0]=0;
int i=0,j=0;
long long D=s/2;
long long ans=0,res=0;
while(i<=j+1&&j<=n)
{
res+=a[++j];
while(res>D) res-=a[i++];
if(res>ans) ans=res;
}
cout<<ans<<"\n";
return 0;
}