#include <bits/stdc++.h>
using namespace std;
using ll = int64_t;
void solve() {
int n = 0;
cin >> n;
vector<ll> vs(n);
for(auto& v : vs) {
cin >> v;
}
vector<ll> vs2 = vs;
for(int i = 1; i < n; i++) {
vs2[i] = vs[i] - vs[i - 1];
}
ll sum = accumulate(vs.begin(), vs.end(), 0ll);
auto check = [&] (ll v) -> bool {
for(int m = 0; m < v; m++) {
ll sum = 0;
ll add = 0;
for(int i = m; i < n; i += v) {
sum += vs2[i];
if(vs2[i] + add < 0) {
return false;
}
add = vs2[i] + add;
}
if(m != n % v) {
if(sum != 0) {
return false;
}
}
}
return true;
};
for(ll i = n; i >= 1; i--) {
if(sum % i != 0) {
continue;
}
if(check(i)) {
cout << i;
return;
}
}
}
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
//freopen("in", "r", stdin);
solve();
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | #include <bits/stdc++.h> using namespace std; using ll = int64_t; void solve() { int n = 0; cin >> n; vector<ll> vs(n); for(auto& v : vs) { cin >> v; } vector<ll> vs2 = vs; for(int i = 1; i < n; i++) { vs2[i] = vs[i] - vs[i - 1]; } ll sum = accumulate(vs.begin(), vs.end(), 0ll); auto check = [&] (ll v) -> bool { for(int m = 0; m < v; m++) { ll sum = 0; ll add = 0; for(int i = m; i < n; i += v) { sum += vs2[i]; if(vs2[i] + add < 0) { return false; } add = vs2[i] + add; } if(m != n % v) { if(sum != 0) { return false; } } } return true; }; for(ll i = n; i >= 1; i--) { if(sum % i != 0) { continue; } if(check(i)) { cout << i; return; } } } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); //freopen("in", "r", stdin); solve(); } |
English