QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#472746#8872. Jumbled StacksPetroTarnavskyi#AC ✓1ms3720kbC++202.3kb2024-07-11 18:59:102024-07-11 18:59:11

Judging History

This is the latest submission verdict.

  • [2024-07-11 18:59:11]
  • Judged
  • Verdict: AC
  • Time: 1ms
  • Memory: 3720kb
  • [2024-07-11 18:59:10]
  • Submitted

answer

#include <bits/stdc++.h>

using namespace std;

#define FOR(i, a, b) for(int i = (a); i < (b); i++)
#define RFOR(i, a, b) for(int i = (a) - 1; i >= (b); i--)
#define SZ(a) int(a.size())
#define ALL(a) a.begin(), a.end()
#define PB push_back
#define MP make_pair
#define F first
#define S second

typedef long long LL;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef double db;

int n, k;
vector<VI> v;
VI c;
int idx = 0;

PII findmin()
{
	PII res = {-1, -1};
	FOR (id, idx, k)
	{
		FOR (pos, 0, SZ(v[id]))
		{
			if (res.F == -1 || v[res.F][res.S] > v[id][pos])
				res = {id, pos};
		}
	}
	return {res.F, SZ(v[res.F]) - res.S - 1};
}

void perenos(int i, int j, int sz)
{
	while (sz--)
	{
		cout << i + 1 << ' ' << j + 1 << '\n';
		v[j].PB(v[i].back());
		v[i].pop_back();
	}
}

void trash(int i, int sz, int banned)
{
	FOR (id, idx, k)
	{
		if (i == id || id == banned)
			continue;
		int can = min(sz, c[id] - SZ(v[id]));
		perenos(i, id, can);
		sz -= can;
	}
}

void f(int K, int cnt)
{
	int i = idx;
	int j = i + 1;
	if (j == K) j++;
	if (SZ(v[j]) == c[j])
		trash(j, 1, -1);
	c[j]--;
	trash(K, cnt, -1);
	perenos(i, j, min(c[j] - SZ(v[j]), SZ(v[i])));
	c[j]++;
	perenos(K, j, 1);
	trash(i, SZ(v[i]), j);
	perenos(j, i, 1);
	v[i].pop_back();
	c[i]--;
	if (c[i] == 0)
		idx++;
}

int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	
	cin >> n >> k;
	v.resize(k);
	c.resize(k);
	FOR (i, 0, k)
	{
		cin >> c[i];
		FOR (j, 0, c[i])
		{
			int x;
			cin >> x;
			if (x)
				v[i].PB(x);
		}
	}
	FOR (i, 0, n)
	{
		if (idx == k - 2)
		{
			v[k - 3].PB(47477474);
			trash(k - 1, SZ(v[k - 1]), -1);
			perenos(k - 3, k - 1, 1);
			int cnt = findmin().S;
			perenos(k - 2, k - 1, cnt);
			perenos(k - 2, k - 3, 1);
			perenos(k - 2, k - 1, SZ(v[k - 2]));
			perenos(k - 3, k - 2, 1);
			v[k - 2].pop_back();
			c[k - 2]--;
			perenos(k - 1, k - 2, SZ(v[k - 1]) - 1);
			perenos(k - 1, k - 3, 1);
			v[k - 3].pop_back();
		}
		else
		{
			auto r = findmin();
			if (r.F == idx)
			{
				trash(idx, SZ(v[idx]), -1);
				r = findmin();
			}
			f(r.F, r.S);
		}
		//FOR (j, 0, k)
		//{
		//	for (auto a : v[j])
		//		cerr << a << ' ';
		//	cerr << '\n';
		//}
		//cerr << "------\n";
	}
	cout << "0 0\n";
	
	return 0;
}


Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3708kb

input:

20 3
1 0
20 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
20 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

output:

2 3
3 1
1 3
2 1
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
1 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 1
1 3
2 1
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
1 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
...

result:

ok correct plan!

Test #2:

score: 0
Accepted
time: 0ms
memory: 3600kb

input:

30 5
22 28 15 25 1 18 30 5 10 2 12 13 14 21 0 0 0 0 0 0 0 0 0
10 29 6 16 24 0 0 0 0 0 0
11 26 20 11 23 19 4 0 0 0 0 0
6 9 3 17 0 0 0
10 27 8 22 7 0 0 0 0 0 0

output:

1 2
1 2
1 2
1 2
1 2
1 2
1 3
1 3
1 3
1 3
1 3
1 4
1 4
2 1
3 1
3 2
1 3
1 3
2 1
3 1
2 3
1 2
3 1
4 1
4 1
4 1
4 2
1 3
1 4
1 4
2 1
3 1
3 1
3 1
3 1
3 1
3 2
1 3
1 3
1 3
1 3
1 3
2 1
3 1
3 1
3 1
3 1
3 2
1 3
1 3
1 3
1 3
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
1 3
2 3
1 2
1 2
1 2
1 2
1 2
1 2
3 1
5 2
2 1
5 1
1 2
5 2
2 1
...

result:

ok correct plan!

Test #3:

score: 0
Accepted
time: 0ms
memory: 3716kb

input:

30 3
1 0
30 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
30 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

output:

2 3
3 1
1 3
2 1
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
1 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 2
3 1
1 3
2 1
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
...

result:

ok correct plan!

Test #4:

score: 0
Accepted
time: 0ms
memory: 3588kb

input:

100 5
58 59 37 45 66 42 50 91 21 48 62 79 2 77 82 55 51 27 73 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
45 71 5 31 97 74 67 3 52 81 39 44 88 41 18 10 80 100 94 70 57 38 35 7 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
38 78 98 61 53 43 86 40 14 64 6 28 33 49 34 ...

output:

3 1
3 1
3 1
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
1 2
3 2
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 3
2 3
3 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
2 1
...

result:

ok correct plan!

Test #5:

score: 0
Accepted
time: 1ms
memory: 3604kb

input:

93 69
2 93 71
1 7
1 23
2 44 32
1 1
2 17 20
1 73
1 55
1 82
1 54
2 80 49
1 72
2 77 57
3 89 51 53
1 58
1 65
1 36
3 38 64 0
2 52 6
2 8 43
1 16
1 35
1 30
1 15
1 12
1 41
1 79
1 28
2 60 29
1 4
1 46
1 13
1 26
2 63 25
1 11
1 18
1 31
1 37
1 59
4 47 21 66 86
1 19
1 0
1 39
1 83
1 91
1 78
1 76
1 68
1 75
1 24
1 4...

output:

2 18
5 2
1 5
1 42
2 1
52 2
2 1
3 2
64 52
64 67
64 3
2 64
3 2
4 3
30 4
3 30
4 3
5 4
52 64
52 5
4 52
4 52
5 4
19 5
5 4
6 5
18 6
5 18
6 5
7 6
20 19
20 7
6 20
6 20
7 6
58 7
7 6
8 7
61 58
61 8
7 61
8 7
9 8
35 9
8 35
9 8
10 9
25 10
9 25
10 9
11 10
32 11
10 32
11 10
12 11
59 61
59 12
11 59
11 59
12 11
24 1...

result:

ok correct plan!

Test #6:

score: 0
Accepted
time: 0ms
memory: 3660kb

input:

89 7
15 75 35 3 87 61 17 72 64 74 34 0 0 0 0 0
8 10 27 2 47 39 46 0 0
18 55 68 28 78 73 48 85 66 7 8 25 41 56 49 42 0 0 0
18 88 71 24 13 57 62 38 29 79 15 32 22 69 83 50 45 0 0
18 59 11 84 60 77 43 9 5 20 33 37 44 54 4 80 0 0 0
19 26 19 16 30 76 23 31 70 6 58 18 51 14 81 53 36 40 0 0
12 52 89 67 82 ...

output:

7 1
7 1
7 1
7 1
1 2
7 2
1 3
1 3
1 3
1 4
1 4
1 5
1 5
1 5
1 6
1 6
1 7
1 7
1 7
2 1
3 1
2 1
2 1
2 1
2 1
2 3
1 2
1 2
1 2
1 2
1 2
3 1
7 1
7 1
7 2
1 3
1 7
2 1
5 1
5 1
5 1
5 1
5 2
1 5
1 5
1 5
1 5
2 1
5 1
5 1
5 1
5 1
5 1
5 1
5 1
5 1
5 1
5 2
1 5
1 5
1 5
1 5
1 5
1 5
1 5
1 5
1 5
2 1
6 1
6 1
6 1
6 1
6 1
6 1
6 1
...

result:

ok correct plan!

Test #7:

score: 0
Accepted
time: 0ms
memory: 3656kb

input:

100 51
2 45 85
2 77 31
2 92 20
2 99 51
2 54 11
2 29 21
2 15 95
2 97 23
2 9 72
2 67 39
2 82 16
2 93 4
2 52 0
2 46 88
2 33 0
2 48 10
2 63 94
2 17 36
2 40 69
2 100 83
2 78 7
2 75 57
2 60 43
2 3 64
2 42 8
2 32 34
2 22 26
2 80 18
2 55 74
2 66 41
2 90 58
2 37 98
2 62 76
2 87 12
2 6 27
2 2 61
2 38 59
2 49 ...

output:

2 13
44 15
44 2
1 44
1 44
2 1
36 1
36 2
1 36
2 1
3 2
24 36
24 3
2 24
2 24
3 2
12 3
3 2
4 3
49 12
49 4
3 49
3 49
4 3
35 3
35 4
3 35
4 3
5 4
21 5
4 21
4 35
5 4
25 5
5 4
6 5
9 25
9 6
5 9
5 9
6 5
16 6
6 5
7 6
21 7
6 16
6 21
7 6
34 7
7 6
8 7
47 34
47 8
7 47
7 47
8 7
43 8
8 7
9 8
47 9
8 43
8 47
9 8
11 9
9...

result:

ok correct plan!

Test #8:

score: 0
Accepted
time: 0ms
memory: 3720kb

input:

100 4
46 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
28 100 99 98 97 96 95 94 93 92 91 90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73
42 72 71 70 69 68 67 66 65 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 ...

output:

2 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
...

result:

ok correct plan!

Test #9:

score: 0
Accepted
time: 0ms
memory: 3596kb

input:

99 100
1 99
1 98
1 97
1 96
1 95
1 94
1 93
1 92
1 91
1 90
1 89
1 88
1 87
1 86
1 85
1 84
1 83
1 82
1 81
1 80
1 79
1 78
1 77
1 76
1 75
1 74
1 73
1 72
1 71
1 70
1 69
1 68
1 67
1 66
1 65
1 64
1 63
1 62
1 61
1 60
1 59
1 58
1 57
1 56
1 55
1 54
1 53
1 52
1 51
1 50
1 49
1 48
1 47
1 46
1 45
1 44
1 43
1 42
1 4...

output:

2 100
99 2
1 99
2 1
3 2
98 3
2 98
3 2
4 3
97 4
3 97
4 3
5 4
96 5
4 96
5 4
6 5
95 6
5 95
6 5
7 6
94 7
6 94
7 6
8 7
93 8
7 93
8 7
9 8
92 9
8 92
9 8
10 9
91 10
9 91
10 9
11 10
90 11
10 90
11 10
12 11
89 12
11 89
12 11
13 12
88 13
12 88
13 12
14 13
87 14
13 87
14 13
15 14
86 15
14 86
15 14
16 15
85 16
1...

result:

ok correct plan!

Test #10:

score: 0
Accepted
time: 1ms
memory: 3660kb

input:

100 3
1 0
100 100 99 98 97 96 95 94 93 92 91 90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 ...

output:

2 3
3 1
1 3
2 1
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
2 3
...

result:

ok correct plan!

Test #11:

score: 0
Accepted
time: 0ms
memory: 3592kb

input:

100 4
43 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
39 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
26 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 ...

output:

1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 3
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
1 4
2 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
4 1
4 2
1 4
2 1
...

result:

ok correct plan!

Test #12:

score: 0
Accepted
time: 0ms
memory: 3596kb

input:

6 3
4 2 3 0 0
3 4 1 6
3 5 0 0

output:

2 1
1 3
2 3
1 2
1 2
3 1
2 3
3 1
2 3
3 1
2 3
3 1
3 2
3 2
1 3
2 1
2 3
1 2
3 2
3 1
1 3
2 1
1 2
3 1
0 0

result:

ok correct plan!