CSES - Datatähti 2016 alku - Results
Submission details
Task:Kirjat
Sender:Destroy();
Submission time:2015-10-04 20:45:05 +0300
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.06 s1details
#20.05 s1details
#30.05 s1details
#40.05 s1details
#50.05 s1details
#60.05 s1details
#70.05 s1details
#80.05 s1details
#90.06 s1details
#100.07 s1details
#110.05 s1details
#120.06 s1details
#130.06 s1details
#140.05 s1details
#150.06 s1details
#160.06 s1details
#170.05 s1details
#180.05 s1details
#190.05 s1details
#200.06 s1details
#210.05 s2details
#220.05 s2details
#230.06 s2details
#240.05 s2details
#250.05 s2details
#260.06 s2details
#270.06 s2details
#280.06 s2details
#290.07 s2details
#300.05 s2details
#310.06 s2details
#320.06 s2details
#330.06 s2details
#340.05 s2details
#350.05 s2details
#360.05 s2details
#370.05 s2details
#380.06 s2details
#390.05 s2details
#400.05 s2details
#410.05 s3details
#420.06 s3details
#430.06 s3details
#440.05 s3details
#450.05 s3details
#460.05 s3details
#470.05 s3details
#480.05 s3details
#490.06 s3details
#500.05 s3details
#510.06 s3details
#520.05 s3details
#530.05 s3details
#540.05 s3details
#550.05 s3details
#56--3details
#57--3details
#58--3details
#59--3details
#60--3details

Code

#include <iostream>
#include <string>
#include <set>
#include <array>

using namespace std;

int main()
{
	int n;
	cin >> n;
	int uolevi[100000];
	int maija[100000];

	for (int i = 0; i < n; i++)
	{
		cin >> uolevi[i];
	}
	for (int i = 0; i < n; i++)
	{
		cin >> maija[i];
	}

	set<int> luvut;

	for (int i = 1; i < n + 1; i++)
	{
		luvut.insert(i);
	}

	int vastaus[10^5];


		if (uolevi[n - 1] != maija[0])
		{
			vastaus[0] = uolevi[n - 1];
			luvut.erase(uolevi[n - 1]);

			if (maija[n - 1] != uolevi[1])
			{
				vastaus[1] = maija[n - 1];
				luvut.erase(maija[n - 1]);
			}
			else
			{
				vastaus[2] = maija[n - 1];
				luvut.erase(maija[n - 1]);
			}
		}
		else
		{
			if (uolevi[n - 1] != maija[1])
			{
				vastaus[1] = uolevi[n - 1];
				luvut.erase(uolevi[n - 1]);

				if (maija[n - 1] != uolevi[0])
				{
					vastaus[0] = maija[n - 1];
					luvut.erase(maija[n - 1]);
				}
				else
				{
					vastaus[2] = maija[n - 1];
					luvut.erase(maija[n - 1]);
				}
			}
		}

		bool aOn = false;
		bool bOn = false;

		for (int i = 0; i < 3; i++)
		{
			if (vastaus[i] < 0)
			{
				int a = uolevi[i];
				if (luvut.find(a) != luvut.end())
				{
					luvut.erase(a);
					aOn = true;
				}

				int b = maija[i];
				if (luvut.find(b) != luvut.end())
				{
					luvut.erase(b);
					bOn = true;
				}

				set<int>::iterator c = luvut.begin();
				//auto c = luvut.begin();
				vastaus[i] = *c;
				luvut.erase(vastaus[i]);

				if (aOn)
				{
					luvut.insert(a);
					aOn = false;
				}
				if (bOn)
				{
					luvut.insert(b);
					bOn = false;
				}
			}
		}

		int yritys = 0;

		if (n > 3)
		{
			for (int i = 3; i < n; i++)
			{
				int random = 0;
				random = rand() % luvut.size();
				set<int>::iterator c = luvut.begin();
				//auto c = luvut.begin();
				advance(c, random);
				//if(random != 0)
					//random -= 1;
				//cout << "random on: " << random << '\n';
				//int c = *luvut.begin() + random;
				//cout << *c << '\n';
				if (uolevi[i] != *c && maija[i] != *c)
				{
					yritys = 0;
					vastaus[i] = *c;
					luvut.erase(*c);
				}
				else
				{
					yritys += 1;
					i -= 1;
					if (yritys == 5)
					{
						yritys = 0;
						i = 2;
					}
					continue;
				}
			}
		}


	/*int j = 0;

	for (int i = 0; i < n/2; n++)
	{
		if (uolevi[0 + i] == maija[n - 1 - j])
		{
			if (maija[0 + i] == uolevi[n - 1 - j])
			{
				j++;
				if (luvut.find(uolevi[n - 1 - j]) != luvut.end())
				{

				}
			}
		}
	}*/

	/*if (uolevi[n - 1] != maija[0])
	{
		vastaus[0] = uolevi[n - 1];
		luvut.erase(uolevi[n - 1]);

		if (maija[n - 1] != uolevi[1])
		{
			vastaus[1] = maija[n - 1];
			luvut.erase(maija[n - 1]);
		}
		else
		{
			vastaus[2] = maija[n - 1];
			luvut.erase(maija[n - 1]);
		}
	}
	else
	{
		if (uolevi[n - 1] != maija[1])
		{
			vastaus[1] = uolevi[n - 1];
			luvut.erase(uolevi[n - 1]);

			if (maija[n - 1] != uolevi[0])
			{
				vastaus[0] = maija[n - 1];
				luvut.erase(maija[n - 1]);
			}
			else
			{
				vastaus[2] = maija[n - 1];
				luvut.erase(maija[n - 1]);
			}
		}
	}

	bool aOn = false;
	bool bOn = false;

	for (int i = 0; i < 3; i++)
	{
		if (vastaus[i] < 0)
		{
			int a = uolevi[i];
			if (luvut.find(a) != luvut.end())
			{
				luvut.erase(a);
				aOn = true;
			}

			int b = maija[i];
			if (luvut.find(b) != luvut.end())
			{
				luvut.erase(b);
				bOn = true;
			}

			auto c = luvut.begin();
			vastaus[i] = *c;
			luvut.erase(vastaus[i]);

			if (aOn)
			{
				luvut.insert(a);
				aOn = false;
			}
			if (bOn)
			{
				luvut.insert(b);
				bOn = false;
			}
		}
	}

	for (int i = 3; i < n; i++)
	{
		for (auto x : luvut) {
			cout << x;
		}
		cout << '\n';

		int a = uolevi[i];
		if (luvut.find(a) != luvut.end())
		{
			aOn = true;
		}
		luvut.erase(a);

		for (auto x : luvut) {
			cout << x;
		}
		cout << '\n';

		int b = maija[i];
		if (luvut.find(b) != luvut.end())
		{
			bOn = true;
		}
		luvut.erase(b);

		for (auto x : luvut) {
			cout << x;
		}
		cout << '\n';

		auto c = luvut.begin();
		vastaus[i] = *c;
		luvut.erase(vastaus[i]);

		for (auto x : luvut) {
			cout << x;
		}
		cout << '\n';

		if (aOn)
		{
			luvut.insert(a);
			aOn = false;
		}
		if (bOn)
		{
			luvut.insert(b);
			bOn = false;
		}

		for (auto x : luvut) {
			cout << x;
		}
		cout << '\n';
	}*/

	for (int i = 0; i < n; i++)
	{
		if(i < n - 1)
			cout << vastaus[i] << ' ';
		else
			cout << vastaus[n-1] << endl;
	}
	//cout << endl;
	cin.get();
	cin.get();
}

Test details

Test 1

Group: 1

Verdict:

input
3
2 1 3
3 2 1

correct output
1 3 2 

user output
1 3 0

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 0 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 0 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 0 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
0 2 4 3

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 0 3 2

Test 7

Group: 1

Verdict:

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

correct output
1 4 5 2 3 

user output
1 4 0 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 0 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
0 4 5 2 1

Test 10

Group: 1

Verdict:

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

correct output
2 5 1 4 3 

user output
2 4 0 3 1

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 0 1 5 3

Test 12

Group: 1

Verdict:

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

correct output
3 1 4 5 2 

user output
3 1 0 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 0 1 5

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 0 3 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 0 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 0 9 8 3 2 1 7 4 10

Test 17

Group: 1

Verdict:

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 0 8 6 10 1 4 2 5

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 0 2 9 4 3 8 1 6 10

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 0 10 7 3 8 9 6 4

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 0 3 8 4 7 5 2 6 1

Test 21

Group: 2

Verdict:

input
3
3 2 1
1 3 2

correct output
2 1 3 

user output
2 1 0

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 0 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 0 4

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 0 4

Test 25

Group: 2

Verdict:

input
4
2 1 3 4
4 3 2 1

correct output
3 4 1 2 

user output
1 4 0 3

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
3 4 0 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
3 5 0 4 2

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 0 4 2 1

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 0 5 3

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 0 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 0 3 2

Test 32

Group: 2

Verdict:

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

correct output
2 3 4 5 1 

user output
3 2 0 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 0 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 0 3 1

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 0 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
731 517 0 194 325 565 181 185 ...

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
437 972 0 194 325 565 181 185 ...

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
975 847 0 194 325 564 181 185 ...

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
288 329 0 194 326 566 181 185 ...

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
995 136 0 195 326 565 182 186 ...

Test 41

Group: 3

Verdict:

input
3
1 2 3
3 1 2

correct output
2 3 1 

user output
2 3 0

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 0 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 0 4

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 0 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 0 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 0 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 0 1 2 5

Test 48

Group: 3

Verdict:

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

correct output
1 2 3 4 5 

user output
2 4 0 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 0 4 3

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 0 2 4

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
3 2 0 4 1

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 0 1 3

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 0 4 3

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 0 4 2

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 0 4 3

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)