Submission details
Task:Maximum sum
Sender:Kemm1706
Submission time:2025-09-15 16:45:25 +0300
Language:C++ (C++11)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#20.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.02 sdetails
#70.02 sdetails
#80.04 sdetails
#90.04 sdetails
#10ACCEPTED0.04 sdetails
#11ACCEPTED0.00 sdetails
#120.00 sdetails
#130.00 sdetails
#140.00 sdetails
#150.00 sdetails

Code

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef vector <ll> vl;

void out(const vl &a)
{
    for(auto x : a)
        cerr << x << " ";
    cerr << "\n";
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0); cout.tie(0);

    ll n, i, ans = 0;
    cin >> n;
    vl a(n), pre(n + 2, 0), pos(n + 2, 0);
    for(i = 0; i < n; i++)
        cin >> a[i];
    for(i = 1; i <= n; i++)
        pre[i] = pre[i - 1] + a[i - 1];
    //out(pre);
    for(i = 1; i <= n; i++)
    {
        pos[i] = max(pre[i], pos[i - 1]);
        pre[i] = min(pre[i], pre[i - 1]);
        ans = max(ans, pos[i] - pre[i]);
    }
    //out(pre); out(pos);
    cout << ans;
    return 0;
}

Test details

Test 1

Verdict: ACCEPTED

input
10
1 1 1 1 1 1 1 1 1 1

correct output
10

user output
10

Test 2

Verdict:

input
10
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1

correct output
-1

user output
10

Test 3

Verdict: ACCEPTED

input
10
24 7 -27 17 -67 65 -23 58 85 -...

correct output
185

user output
185

Test 4

Verdict: ACCEPTED

input
10
99 -59 31 83 -79 64 -20 -87 40...

correct output
154

user output
154

Test 5

Verdict: ACCEPTED

input
10
-19 61 60 33 67 19 -8 92 59 -3...

correct output
383

user output
383

Test 6

Verdict: ACCEPTED

input
200000
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...

correct output
200000

user output
200000

Test 7

Verdict:

input
200000
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...

correct output
-1

user output
200000

Test 8

Verdict:

input
200000
381082742 830199996 -85684827 ...

correct output
231210956017

user output
290349242083

Test 9

Verdict:

input
200000
-935928962 -795492223 75287481...

correct output
184607318819

user output
388529380407

Test 10

Verdict: ACCEPTED

input
200000
524408131 613017181 -62281009 ...

correct output
360019999220

user output
360019999220

Test 11

Verdict: ACCEPTED

input
1
1

correct output
1

user output
1

Test 12

Verdict:

input
1
-2

correct output
-2

user output
2

Test 13

Verdict:

input
5
-1 -1 -1 -1 -2

correct output
-1

user output
6

Test 14

Verdict:

input
2
-3 -2

correct output
-2

user output
5

Test 15

Verdict:

input
1
-1000000000

correct output
-1000000000

user output
1000000000