NOIP第二轮模拟 Day2 圆圈跳舞

【问题描述】

熊大妈的奶牛在时针的带领下,围成了一个圆圈跳舞。由于没有严格的教育,奶牛们之间的间隔不一致。

奶牛想知道两只最远的奶牛到底隔了多远。奶牛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;
}

猜你喜欢

转载自blog.csdn.net/xyc1719/article/details/80959185
今日推荐