CSES - Aalto Competitive Programming 2024 - wk3 - Mon - Results
Submission details
Task:Maximum sum
Sender:snude
Submission time:2024-09-16 17:26:14 +0300
Language:C++11
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.04 sdetails
#7ACCEPTED0.05 sdetails
#8ACCEPTED0.10 sdetails
#9ACCEPTED0.10 sdetails
#10ACCEPTED0.10 sdetails
#11ACCEPTED0.00 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.00 sdetails
#15ACCEPTED0.00 sdetails

Code

#include <cstdio>
#include <iostream>
#include <vector>

using namespace std;

int main(int argc, char *argv[])
{
	long n;
	std::cin >> n;

	vector<long> numbers(n);
	for (long i = 0; i < n; i++) {
		cin >> numbers[i];
	}

	long result = numbers[0];
    vector<long> sums(n, 0);

    // vector<long> sums(n);
    // sums[0] = max(numbers[0], 0L);
    // for (int i = 0; i < n; i++) {
    //     long mid_sum = 0;
    //     for (int j = i; j >= 0; j--) {
    //         mid_sum = mid_sum + numbers[j];
    //     }
    // }

    sums[0] = numbers[0];
    long sum = numbers[0];
	for (long i = 1; i < n; i++) {
        if (sums[i - 1] < 1) {
            sum = numbers[i];
        } else {
            sum = sums[i - 1] + numbers[i];
            // sums[i] = sum;
        }
        sums[i] = sum;
        if (sums[i] > result) result = sums[i];
        
		// long mid_sum = 0;

		// for (long j = i; j >= 0; j--) {
		// 	mid_sum = mid_sum + numbers[j];
  //           result = max(result, mid_sum);
		// }
	}
	std::cout << result << "\n";
	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: ACCEPTED

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

correct output
-1

user output
-1

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