Submission details
Task:Maximum sum
Sender:hundlij1
Submission time:2025-09-15 17:46:07 +0300
Language:C++ (C++17)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.04 sdetails
#7ACCEPTED0.04 sdetails
#8ACCEPTED0.10 sdetails
#9ACCEPTED0.10 sdetails
#10ACCEPTED0.10 sdetails
#11ACCEPTED0.00 sdetails
#12ACCEPTED0.01 sdetails
#130.00 sdetails
#14ACCEPTED0.00 sdetails
#15ACCEPTED0.00 sdetails

Code

#include <iostream>
#include <algorithm>
#include <queue>
using namespace std;




void t1(){
    int n, m, k;
    cin >> n >> m >> k;

    const int MOD = n * 100;

    vector<int> pos(k + 1, 0);
    vector<int> speed(k + 1, 0);


    vector<int> val(n);

    for(int i = 0; i < m; i++){
        int a;
        cin >> a;
        val[a] = 1;
    }

    int posC = 0;
    for(int i = 0; i < k; i++){
        if(val[posC] == 0){
            pos[i+1] = (pos[i] + 100) % MOD;
            posC +=1;
            posC %= n;
        } 
        else if(val[posC] == 1){
            pos[i+1] = (pos[i] + 200) % MOD;
            posC +=2;
            posC %= n;

        }
    }
    //for(int i = 0; i <= k; i++)
    //cout << i << pos[i] << endl;

    cout << pos[k] << endl;
}




void t2(){
    int n;
    cin >> n;
    vector<int> nums(n +1,0);
    for(int i = 0; i < n; i++){
        cin >> nums[i];
    }

    long long min = 0;
    //int minPos = 0;
    long long max = nums[0];
    //int maxPos = n-1;

    vector<long long > dp(n,0);

    for(int i = 0; i < n; i++){
       dp[i +1] += dp[i] + nums[i];

       
       if((dp[i +1] - min) > max){
           max = dp[i+1] - min;
           //maxPos = i;
       }
       if(dp[i+1] < min){
           min = dp[i+1];
          // minPos = i;
       }
    }

    /*if(minPos + 1 > n) min = dp[minPos -1];
    else if(minPos - 1 < 0) min = dp[minPos + 1];
    else if(dp[minPos + 1] > dp[minPos -1]){
        min = dp[minPos + 1];
    }
    else {
        min = dp[minPos - 1];
    }*/


    //int maxDiff = max - min;
    //int v = minPos+maxPos;
    //cout << max << "  " << min << endl;
    cout << max << endl;


}







int main() {
    t2();
    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: ACCEPTED

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

correct output
-1

user output
-1

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: ACCEPTED

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

correct output
-1

user output
-1

Test 8

Verdict: ACCEPTED

input
200000
381082742 830199996 -85684827 ...

correct output
231210956017

user output
231210956017

Test 9

Verdict: ACCEPTED

input
200000
-935928962 -795492223 75287481...

correct output
184607318819

user output
184607318819

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: ACCEPTED

input
1
-2

correct output
-2

user output
-2

Test 13

Verdict:

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

correct output
-1

user output
57599

Test 14

Verdict: ACCEPTED

input
2
-3 -2

correct output
-2

user output
-2

Test 15

Verdict: ACCEPTED

input
1
-1000000000

correct output
-1000000000

user output
-1000000000