思路
枚举环形数组, 然后找比周长一半大的, 最小的那个, 然后用 周长减去这个值, 就是答案
ac代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
int n;
cin >> n;
vector<int> a(n + 1);
int s = 0;
for (int i = 0; i < n; i++)
{
cin >> a[i];
s += a[i];
}
int hf = s / 2;
int dis = 0;
int res = 0;
for (int i = 0, j = 0; i < n; i++)
{
while (dis < hf)
{
dis += a[j % n];
j++;
}
res = max(res, min(dis, s - dis));
dis -= a[i];
}
cout <<res <<endl;
return 0;
}