CSES - Datatähti 2016 alku - Results
Submission details
Task:Kirjat
Sender:viderizer
Submission time:2015-09-30 18:47:52 +0300
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.05 s1details
#20.06 s1details
#30.06 s1details
#40.06 s1details
#50.05 s1details
#60.06 s1details
#7ACCEPTED0.06 s1details
#80.05 s1details
#90.06 s1details
#10ACCEPTED0.05 s1details
#110.05 s1details
#12ACCEPTED0.06 s1details
#130.06 s1details
#140.06 s1details
#150.05 s1details
#160.05 s1details
#17ACCEPTED0.05 s1details
#180.05 s1details
#190.05 s1details
#200.05 s1details
#210.05 s2details
#220.05 s2details
#230.06 s2details
#240.06 s2details
#250.08 s2details
#260.06 s2details
#270.05 s2details
#280.06 s2details
#290.06 s2details
#300.06 s2details
#310.07 s2details
#32ACCEPTED0.06 s2details
#330.05 s2details
#340.05 s2details
#350.07 s2details
#360.06 s2details
#370.05 s2details
#380.06 s2details
#390.06 s2details
#400.05 s2details
#410.05 s3details
#420.06 s3details
#430.05 s3details
#440.06 s3details
#450.06 s3details
#460.06 s3details
#470.06 s3details
#48ACCEPTED0.06 s3details
#490.05 s3details
#500.06 s3details
#510.05 s3details
#520.05 s3details
#530.05 s3details
#540.05 s3details
#550.05 s3details
#560.07 s3details
#570.06 s3details
#580.06 s3details
#590.06 s3details
#600.06 s3details

Code

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <tuple>
#include <set>
#include <algorithm>

using std::string;
using std::cin;
using std::cout;
using std::stoi;
using std::tuple;
using std::vector;
using std::stringstream;
using std::make_tuple;
using std::tuple_element;
using std::getline;
using std::get;
using std::find;

void debug(vector<int> v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); ++it) {
        cout << *it << " ";
    }

    cout << "\n";
}

int main(int argc, char** argv) {
    // input
    int n;
    string n_s;
    string uolevi;
    string maija;

    getline(cin, n_s);
    n = stoi(n_s);
    if (n > 100) {
        return 1;
    }
    getline(cin, uolevi);
    getline(cin, maija);

    // parsing input
    vector<tuple<int, int, int>> v;
    stringstream ss(uolevi);
    stringstream ss2(maija);
    string sub;
    string sub2;

    while (getline(ss, sub, ' ') && getline(ss2, sub2, ' ')) {
        v.push_back(make_tuple(stoi(sub), stoi(sub2), 0));
    }

    vector<int> unread;
    for (vector<tuple<int, int, int>>::reverse_iterator it = v.rbegin(); it != v.rend(); ++it) {
        if (find(unread.begin(), unread.end(), get<0>(*it)) == unread.end()) {
            unread.push_back(get<0>(*it));
        }
        if (find(unread.begin(), unread.end(), get<1>(*it)) == unread.end()) {
            unread.push_back(get<1>(*it));
        }
    }

    debug(unread);

    stringstream result_ss;

    for (vector<tuple<int, int, int>>::iterator it = v.begin(); it != v.end(); ++it) {
        for (vector<int>::iterator it2 = unread.begin(); it2 != unread.end(); ++it2) {
            if (*it2 != get<0>(*it) && *it2 != get<1>(*it)) {
                *it = make_tuple(get<0>(*it), get<1>(*it), *it2);
                unread.erase(it2);
                break;
            }
        }
        if ((get<2>(*it) == 0) && (it + 2 == v.end())) {
            return 1;
        }
        //cout << "(" << get<0>(*it) << ", " << get<1>(*it) << ", " << get<2>(*it) << "), ";
        result_ss << get<2>(*it) << " ";
    }



    string result_s(result_ss.str());
    result_s.pop_back();

    cout << result_s << "\n";
    return 0;
}

Test details

Test 1

Group: 1

Verdict:

input
3
2 1 3
3 2 1

correct output
1 3 2 

user output
3 1 2 
1 3 2

Test 2

Group: 1

Verdict:

input
4
2 1 4 3
1 4 3 2

correct output
4 3 2 1 

user output
3 2 4 1 
3 2 1 4

Test 3

Group: 1

Verdict:

input
4
4 3 2 1
3 1 4 2

correct output
1 2 3 4 

user output
1 2 4 3 
1 2 3 4

Test 4

Group: 1

Verdict:

input
4
3 4 2 1
2 3 1 4

correct output
1 2 4 3 

user output
1 4 2 3 
1 2 4 3

Test 5

Group: 1

Verdict:

input
4
4 1 3 2
2 3 1 4

correct output
1 4 2 3 

user output
2 4 3 1 
3 2 4 1

Test 6

Group: 1

Verdict:

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

correct output
2 3 4 5 1 

user output
4 5 2 1 3 
4 5 1 3 2

Test 7

Group: 1

Verdict: ACCEPTED

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

correct output
1 4 5 2 3 

user output
1 4 5 3 2 
1 4 5 3 2

Test 8

Group: 1

Verdict:

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

correct output
3 2 5 1 4 

user output
5 2 3 1 4 
5 2 4 3 1

Test 9

Group: 1

Verdict:

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

correct output
1 4 5 2 3 

user output
4 5 1 3 2 
1 4 5 2 3

Test 10

Group: 1

Verdict: ACCEPTED

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

correct output
2 5 1 4 3 

user output
2 4 1 5 3 
2 4 1 5 3

Test 11

Group: 1

Verdict:

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

correct output
3 4 2 1 5 

user output
4 1 2 3 5 
4 2 1 5 3

Test 12

Group: 1

Verdict: ACCEPTED

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

correct output
3 1 4 5 2 

user output
3 1 4 2 5 
3 1 4 2 5

Test 13

Group: 1

Verdict:

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

correct output
3 2 5 1 4 

user output
3 2 4 5 1 
3 2 5 1 4

Test 14

Group: 1

Verdict:

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

correct output
1 2 3 4 5 

user output
1 4 2 3 5 
1 4 3 5 2

Test 15

Group: 1

Verdict:

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

correct output
5 3 2 1 4 

user output
1 5 2 4 3 
1 4 5 3 2

Test 16

Group: 1

Verdict:

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

correct output
3 1 9 2 4 7 8 6 5 10 

user output
5 9 3 2 10 7 4 8 6 1 
5 3 9 2 10 7 8 4 6 1

Test 17

Group: 1

Verdict: ACCEPTED

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

correct output
5 7 1 3 9 2 4 10 6 8 

user output
9 7 4 8 1 3 5 6 2 10 
9 7 4 8 1 3 5 6 2 10

Test 18

Group: 1

Verdict:

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

correct output
1 6 8 9 5 4 10 3 2 7 

user output
5 2 3 1 7 10 4 9 6 8 
5 3 2 1 7 10 6 4 9 8

Test 19

Group: 1

Verdict:

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

correct output
5 1 6 2 8 10 7 3 9 4 

user output
2 5 1 4 10 7 6 3 9 8 
2 5 1 4 10 3 7 6 9 8

Test 20

Group: 1

Verdict:

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

correct output
1 5 7 3 10 6 9 4 2 8 

user output
9 3 1 7 4 6 10 2 5 8 
9 1 3 7 4 6 10 2 5 8

Test 21

Group: 2

Verdict:

input
3
3 2 1
1 3 2

correct output
2 1 3 

user output
1 2 3 
2 1 3

Test 22

Group: 2

Verdict:

input
4
2 3 1 4
1 4 3 2

correct output
3 2 4 1 

user output
4 2 1 3 

Test 23

Group: 2

Verdict:

input
4
2 4 3 1
4 1 2 3

correct output
3 2 1 4 

user output
1 3 2 4 
1 3 4 2

Test 24

Group: 2

Verdict:

input
4
4 1 2 3
1 3 4 2

correct output
3 2 1 4 

user output
3 2 4 1 
3 2 1 4

Test 25

Group: 2

Verdict:

input
4
2 1 3 4
4 3 2 1

correct output
3 4 1 2 

user output
4 1 3 2 

Test 26

Group: 2

Verdict:

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

correct output
5 4 2 3 1 

user output
4 3 1 5 2 
3 4 5 2 1

Test 27

Group: 2

Verdict:

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

correct output
4 5 2 3 1 

user output
5 3 2 1 4 
3 5 2 4 1

Test 28

Group: 2

Verdict:

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

correct output
4 5 3 1 2 

user output
5 4 3 2 1 
5 2 4 1 3

Test 29

Group: 2

Verdict:

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

correct output
1 2 3 4 5 

user output
1 4 3 2 5 
1 4 3 5 2

Test 30

Group: 2

Verdict:

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

correct output
4 5 2 3 1 

user output
4 2 5 1 3 
4 5 2 3 1

Test 31

Group: 2

Verdict:

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

correct output
4 5 2 3 1 

user output
4 5 2 1 3 
4 5 2 3 1

Test 32

Group: 2

Verdict: ACCEPTED

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

correct output
2 3 4 5 1 

user output
3 2 4 1 5 
3 2 4 1 5

Test 33

Group: 2

Verdict:

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

correct output
5 1 3 2 4 

user output
2 1 3 4 5 
2 1 3 5 4

Test 34

Group: 2

Verdict:

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

correct output
2 3 4 5 1 

user output
5 2 1 4 3 
5 2 1 3 4

Test 35

Group: 2

Verdict:

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

correct output
1 2 3 4 5 

user output
4 3 5 1 2 
4 5 3 2 1

Test 36

Group: 2

Verdict:

input
1000
63 72 78 267 740 551 517 698 6...

correct output
26 926 267 321 385 444 968 690...

user output
(empty)

Test 37

Group: 2

Verdict:

input
1000
954 273 839 263 331 161 938 51...

correct output
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
(empty)

Test 38

Group: 2

Verdict:

input
1000
740 142 781 837 759 392 582 14...

correct output
111 291 702 70 561 469 707 897...

user output
(empty)

Test 39

Group: 2

Verdict:

input
1000
960 550 210 529 691 277 63 975...

correct output
716 604 535 519 27 204 574 592...

user output
(empty)

Test 40

Group: 2

Verdict:

input
1000
371 772 197 202 504 931 4 46 6...

correct output
26 926 267 321 385 444 968 690...

user output
(empty)

Test 41

Group: 3

Verdict:

input
3
1 2 3
3 1 2

correct output
2 3 1 

user output
3 2 1 
2 3 1

Test 42

Group: 3

Verdict:

input
4
4 2 3 1
2 3 1 4

correct output
1 4 2 3 

user output
1 4 3 2 
1 4 2 3

Test 43

Group: 3

Verdict:

input
4
2 1 4 3
4 3 1 2

correct output
1 2 3 4 

user output
3 2 4 1 

Test 44

Group: 3

Verdict:

input
4
1 4 2 3
2 3 4 1

correct output
3 2 1 4 

user output
3 1 2 4 

Test 45

Group: 3

Verdict:

input
4
2 1 4 3
1 3 2 4

correct output
4 2 3 1 

user output
3 4 2 1 
3 4 1 2

Test 46

Group: 3

Verdict:

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

correct output
1 2 3 4 5 

user output
4 3 2 1 5 
4 3 1 5 2

Test 47

Group: 3

Verdict:

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

correct output
4 5 3 1 2 

user output
4 1 3 5 2 
4 5 1 2 3

Test 48

Group: 3

Verdict: ACCEPTED

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

correct output
1 2 3 4 5 

user output
2 4 3 1 5 
2 4 3 1 5

Test 49

Group: 3

Verdict:

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

correct output
5 1 3 2 4 

user output
5 2 3 1 4 
5 2 3 4 1

Test 50

Group: 3

Verdict:

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

correct output
1 4 5 2 3 

user output
1 5 4 3 2 

Test 51

Group: 3

Verdict:

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

correct output
1 2 3 4 5 

user output
2 3 5 1 4 
3 2 4 1 5

Test 52

Group: 3

Verdict:

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

correct output
5 2 1 4 3 

user output
4 5 2 3 1 
4 5 3 1 2

Test 53

Group: 3

Verdict:

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

correct output
5 3 2 1 4 

user output
2 1 3 5 4 

Test 54

Group: 3

Verdict:

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

correct output
2 3 4 5 1 

user output
3 5 2 1 4 
3 5 2 4 1

Test 55

Group: 3

Verdict:

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

correct output
1 2 5 3 4 

user output
1 2 3 4 5 
1 2 5 3 4

Test 56

Group: 3

Verdict:

input
100000
74620 99226 537 63830 13777 69...

correct output
44158 25720 84658 90057 99607 ...

user output
(empty)

Test 57

Group: 3

Verdict:

input
100000
67665 19864 90761 58104 38796 ...

correct output
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
(empty)

Test 58

Group: 3

Verdict:

input
100000
63021 24161 40379 69157 89616 ...

correct output
4913 70683 13897 99969 66725 3...

user output
(empty)

Test 59

Group: 3

Verdict:

input
100000
31500 70052 90949 56812 73871 ...

correct output
47064 17335 15460 80797 56435 ...

user output
(empty)

Test 60

Group: 3

Verdict:

input
100000
39127 4446 57817 67459 53741 8...

correct output
96591 75698 82505 59416 72144 ...

user output
(empty)