CSES - Datatähti 2017 alku - Results
Submission details
Task:Kolikot
Sender:miksu.r
Submission time:2016-10-15 00:42:31 +0300
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.06 s1details
#20.05 s1details
#30.06 s1details
#40.05 s1details
#50.05 s1details
#60.40 s2details
#70.06 s2details
#80.05 s2details
#90.39 s2details
#100.39 s2details
#110.40 s3details
#120.07 s3details
#130.10 s3details
#140.43 s3details
#150.44 s3details
#160.43 s3details

Code

#include <iostream>
#include <vector>
#include <string>
#include <sstream>
#include <math.h>
#include <algorithm>

using namespace std;

unsigned long n;
string inf;
string ins;
string tmp;
unsigned long index;
unsigned long timer;
vector<unsigned long> perms;

int main(){
	
	getline(cin, inf);
	n = stoul(inf);
	
	unsigned long x[n];
	
	getline(cin, ins);
	stringstream t(ins);
	
	index = 0;
	while(t >> tmp){
		x[index] = stoul(tmp);
		index++;
	}
	
	if(n == 1){
		cout << x[0];
		return 0;
	}
	
	sort(x, x + n);

	perms.push_back(x[0]);
	perms.push_back(x[1]);
	perms.push_back(x[1]+x[0]);
	
	index = 0;
	for(short i = 0; i < 3; i++){
		if(perms[i] == index + 1){
			index++;
		}
	}
	
	for(unsigned long i = 2; i < n; i++){
		perms.push_back(x[i]);
		if(perms[perms.size() - 1] == index + 1){
			index++;
		}
		timer = perms.size();
		for(unsigned long j = 0; j < timer - 1; j++){
			perms.push_back(perms[j] + x[i]);
			if(perms[perms.size() - 1] == index + 1){
				index++;
			}
		}
		if(i > index){
			break;
		}
	}
	
	cout << index << endl;
	
	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
29

Test 2

Group: 1

Verdict:

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

correct output
1

user output
0

Test 3

Group: 1

Verdict:

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

correct output
62

user output
61

Test 4

Group: 1

Verdict:

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

correct output
1

user output
0

Test 5

Group: 1

Verdict:

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

correct output
51

user output
50

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
(empty)

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

Test 8

Group: 2

Verdict:

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

correct output
1

user output
0

Test 9

Group: 2

Verdict:

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

correct output
30

user output
(empty)

Test 10

Group: 2

Verdict:

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

correct output
41765

user output
(empty)

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
0

Test 13

Group: 3

Verdict:

input
100000
98146842 766872135 84108268 28...

correct output
1

user output
0

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)