// #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; scanf("%d", &N); vector< pair > A(N); for(int i=0; i 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= 0 and bl - ar < -1) r--, bl += K, br += K; if(r >= 0) chmax(ans, K * (CL[l] + CR[r])); } } printf("%lld\n", ans); return 0; }