CSES - Datatähti 2017 alku - Results
Submission details
Task:Kolikot
Sender:comp
Submission time:2016-10-08 00:09:01 +0300
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.05 s1details
#20.05 s1details
#30.05 s1details
#40.05 s1details
#50.05 s1details
#60.05 s2details
#70.06 s2details
#80.24 s2details
#90.21 s2details
#100.21 s2details
#11--3details
#12--3details
#131.89 s3details
#14--3details
#151.85 s3details
#16--3details

Code

#include <iostream>
#include <set>
#include <vector>

int hasnt_skipped(std::set<int> &sums) {
    int previous = *(sums.begin());
    int highest = *(sums.rbegin());
    while (previous != highest) {
        if (sums.find(previous + 1) != sums.end()) {
            previous += 1;
            continue;
        } else {
            return previous + 1;
        }
    }
    return previous + 1;
}


int main() {
    int n;
    std::cin >> n;
    std::vector<int> coins;
    
    for(int i = 0; i < n; ++i) {
        int x;
        std::cin >> x;
        coins.push_back(x);
    }
    
    std::set<int> sofar;
    std::vector<int> news;
    
    sofar.insert(0);
    
    int min_sum = 0;
    
    for(auto v: coins) {
        for(auto s: sofar) {
            news.push_back(v + s);
        }
        for(auto n: news) {
            sofar.insert(n);
        }
        news.clear();
    }
    for(auto e: sofar) {
        std::cout << e << ";";
    }
    min_sum = hasnt_skipped(sofar);
    std::cout << min_sum;
    return 0;
}

Test details

Test 1

Group: 1

Verdict:

input
10
5 3 1 4 5 1 3 2 2 3

correct output
30

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 2

Group: 1

Verdict:

input
10
3 5 5 4 5 4 5 5 5 3

correct output
1

user output
0;3;4;5;6;7;8;9;10;11;12;13;14...

Test 3

Group: 1

Verdict:

input
10
10 9 2 8 7 10 7 1 5 2

correct output
62

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 4

Group: 1

Verdict:

input
10
7 4 6 3 9 7 4 4 7 7

correct output
1

user output
0;3;4;6;7;8;9;10;11;12;13;14;1...

Test 5

Group: 1

Verdict:

input
10
8 2 1 7 9 7 5 2 4 5

correct output
51

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 6

Group: 2

Verdict:

input
100
3 3 1 4 2 1 2 1 3 1 2 5 1 5 1 ...

correct output
269

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 7

Group: 2

Verdict:

input
100
3 3 2 3 4 5 4 4 4 4 2 2 4 4 4 ...

correct output
1

user output
0;2;3;4;5;6;7;8;9;10;11;12;13;...

Test 8

Group: 2

Verdict:

input
100
678 999 374 759 437 390 832 54...

correct output
1

user output
0;17;24;36;38;41;50;53;55;59;6...

Test 9

Group: 2

Verdict:

input
100
862 537 633 807 666 248 237 5 ...

correct output
30

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 10

Group: 2

Verdict:

input
100
874 302 384 920 76 28 762 163 ...

correct output
41765

user output
0;1;2;3;4;5;6;7;8;9;10;11;12;1...

Test 11

Group: 3

Verdict:

input
100000
4 2 5 3 2 3 5 2 2 2 3 4 3 3 2 ...

correct output
299640

user output
(empty)

Test 12

Group: 3

Verdict:

input
100000
2 5 5 5 5 2 4 4 3 2 3 2 5 5 3 ...

correct output
1

user output
(empty)

Test 13

Group: 3

Verdict:

input
100000
98146842 766872135 84108268 28...

correct output
1

user output
(empty)

Test 14

Group: 3

Verdict:

input
100000
932032495 1 849176169 78948957...

correct output
29970

user output
(empty)

Test 15

Group: 3

Verdict:

input
100000
35894853 796619259 699878597 4...

correct output
44965249639582

user output
(empty)

Test 16

Group: 3

Verdict:

input
100000
930494676 960662779 904422858 ...

correct output
800020001

user output
(empty)