// #define _GLIBCXX_DEBUG // for STL debug (optional) #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll = long long int; using int64 = long long int; template void chmax(T &a, T b) {a = max(a, b);} template void chmin(T &a, T b) {a = min(a, b);} template void chadd(T &a, T b) {a = a + b;} int dx[] = {0, 0, 1, -1}; int dy[] = {1, -1, 0, 0}; const int INF = 1LL << 29; const ll LONGINF = 1LL << 60; const ll MOD = 1000000007LL; int main() { int N; cin >> N; vector< pair > A(N); for(int i=0; i> v; A[i] = make_pair(v, i); } sort(A.begin(), A.end()); vector L(N), R(N), CL(N), CR(N); ll ans = 0; for(int K=1; K<=N; K++) { int B = N / K; fill(L.begin(), L.begin() + B, 0); fill(R.begin(), R.begin() + B, 0); int half = (K + 1) / 2; for(int i=0; i= B) continue; if(++L[b] == half) CL[b] = A[i].first; } for(int i=0; i= B) continue; if(++R[b] == half) CR[b] = A[i].first; } for(int i=1; i= 0 and bl - ar < -1) r--, bl += K, br += K; if(r >= 0) chmax(ans, K * (CL[l] + CR[r])); } } cout << ans << endl; return 0; }