# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
633880 | 2022-08-23T11:08:48 Z | lovrot | Nice sequence (IZhO18_sequence) | C++11 | 2000 ms | 2000 KB |
#include <bits/stdc++.h> #define pb push_back #define X first #define Y second #define pii pair<int, int> using namespace std; const int N = 2 * 1e5 + 10; int n, m, p[N], g[N][2], ans; int stk[N], pos; int cyc[N], bio[N], ts[N], cookie; int stackTop(){ return stk[pos]; } void stackPop(){ pos--; } void stackPush(int x){ pos++; stk[pos] = x; p[x] = pos; } bool cycp(int u){ bio[u] = cookie; cyc[u] = cookie; // cout << u << "\n"; int lv = u - m, uv = u + n; if(lv >= 0){ if(cyc[lv] == cookie) return true; if(cycp(lv)) return true; } if(uv <= ans){ if(cyc[uv] == cookie) return true; if(cycp(uv)) return true; } cyc[u] = -cookie; return false; } void topSort(int u){ ts[u] = cookie; int lv = u - m, uv = u + n; if(lv >= 0){ if(ts[lv] != cookie) topSort(lv); } if(uv <= ans){ if(ts[uv] != cookie) topSort(uv); } stackPush(u); } void output(){ for(int i = 0; i <= ans; i++) if(ts[i] != cookie) topSort(i); printf("%d\n", ans); for(int i = 1; i <= ans; i++) printf("%d ", (p[i] - p[0]) - (p[i - 1] - p[0])); printf("\n"); } bool probaj(){ pos = -1; cookie++; // for(int i = 0; i <= ans; i++){ // g[i][0] = g[i][1] = -1; // if(i - m >= 0) g[i][0] = i - m; // if(i - n >= 0) g[i - n][1] = i; // } // for(int i = 0; i <= x; i++) cout << i << ": " << g[i][0] << " " << g[i][1] << "\n"; for(int i = 0; i <= ans; i++){ if(bio[i] != cookie){ if(cycp(i)) return false; } } return true; } void task(){ scanf("%d %d", &n, &m); int lo = 0, hi = (n + m) + 1; while(hi - lo > 1){ int mi = (lo + hi) / 2; ans = mi; if(probaj()) lo = mi; else hi = mi; } ans = lo; probaj(); output(); } int main() { ios_base::sync_with_stdio(false); int t; scanf("%d", &t); while(t--){ task(); } return 0; }
Compilation message
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 1 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 1 ms | 340 KB | Ok |
5 | Correct | 1 ms | 340 KB | Ok |
6 | Correct | 1 ms | 340 KB | Ok |
7 | Correct | 0 ms | 340 KB | Ok |
8 | Correct | 1 ms | 340 KB | Ok |
9 | Correct | 1 ms | 340 KB | Ok |
10 | Correct | 1 ms | 340 KB | Ok |
11 | Correct | 1 ms | 340 KB | Ok |
12 | Correct | 0 ms | 340 KB | Ok |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 0 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 0 ms | 340 KB | Ok |
5 | Correct | 0 ms | 340 KB | Ok |
6 | Correct | 223 ms | 476 KB | Ok |
7 | Execution timed out | 2092 ms | 1084 KB | Time limit exceeded |
8 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 0 ms | 340 KB | Ok |
3 | Correct | 1 ms | 340 KB | Ok |
4 | Correct | 0 ms | 340 KB | Ok |
5 | Correct | 0 ms | 340 KB | Ok |
6 | Correct | 0 ms | 340 KB | Ok |
7 | Correct | 0 ms | 340 KB | Ok |
8 | Correct | 0 ms | 340 KB | Ok |
9 | Correct | 1 ms | 340 KB | Ok |
10 | Correct | 0 ms | 340 KB | Ok |
11 | Correct | 0 ms | 340 KB | Ok |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 340 KB | Ok |
2 | Correct | 0 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 0 ms | 340 KB | Ok |
5 | Correct | 0 ms | 340 KB | Ok |
6 | Execution timed out | 2091 ms | 2000 KB | Time limit exceeded |
7 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 1 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 1 ms | 340 KB | Ok |
5 | Correct | 1 ms | 340 KB | Ok |
6 | Correct | 1 ms | 340 KB | Ok |
7 | Correct | 0 ms | 340 KB | Ok |
8 | Correct | 1 ms | 340 KB | Ok |
9 | Correct | 1 ms | 340 KB | Ok |
10 | Correct | 1 ms | 340 KB | Ok |
11 | Correct | 1 ms | 340 KB | Ok |
12 | Correct | 0 ms | 340 KB | Ok |
13 | Correct | 1 ms | 340 KB | Ok |
14 | Correct | 0 ms | 340 KB | Ok |
15 | Correct | 1 ms | 340 KB | Ok |
16 | Correct | 0 ms | 340 KB | Ok |
17 | Correct | 0 ms | 340 KB | Ok |
18 | Correct | 0 ms | 340 KB | Ok |
19 | Correct | 0 ms | 340 KB | Ok |
20 | Correct | 0 ms | 340 KB | Ok |
21 | Correct | 1 ms | 340 KB | Ok |
22 | Correct | 0 ms | 340 KB | Ok |
23 | Correct | 0 ms | 340 KB | Ok |
24 | Correct | 4 ms | 340 KB | Ok |
25 | Correct | 4 ms | 340 KB | Ok |
26 | Correct | 4 ms | 340 KB | Ok |
27 | Correct | 4 ms | 468 KB | Ok |
28 | Correct | 3 ms | 340 KB | Ok |
29 | Correct | 3 ms | 340 KB | Ok |
30 | Correct | 4 ms | 340 KB | Ok |
31 | Correct | 3 ms | 340 KB | Ok |
32 | Correct | 3 ms | 340 KB | Ok |
33 | Correct | 6 ms | 436 KB | Ok |
34 | Correct | 27 ms | 584 KB | Ok |
35 | Correct | 34 ms | 680 KB | Ok |
36 | Correct | 78 ms | 728 KB | Ok |
37 | Correct | 26 ms | 748 KB | Ok |
38 | Correct | 32 ms | 736 KB | Ok |
39 | Correct | 20 ms | 720 KB | Ok |
40 | Correct | 38 ms | 716 KB | Ok |
41 | Correct | 30 ms | 716 KB | Ok |
42 | Correct | 28 ms | 724 KB | Ok |
43 | Correct | 30 ms | 700 KB | Ok |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 1 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 1 ms | 340 KB | Ok |
5 | Correct | 1 ms | 340 KB | Ok |
6 | Correct | 1 ms | 340 KB | Ok |
7 | Correct | 0 ms | 340 KB | Ok |
8 | Correct | 1 ms | 340 KB | Ok |
9 | Correct | 1 ms | 340 KB | Ok |
10 | Correct | 1 ms | 340 KB | Ok |
11 | Correct | 1 ms | 340 KB | Ok |
12 | Correct | 0 ms | 340 KB | Ok |
13 | Correct | 1 ms | 340 KB | Ok |
14 | Correct | 0 ms | 340 KB | Ok |
15 | Correct | 0 ms | 340 KB | Ok |
16 | Correct | 0 ms | 340 KB | Ok |
17 | Correct | 0 ms | 340 KB | Ok |
18 | Correct | 223 ms | 476 KB | Ok |
19 | Execution timed out | 2092 ms | 1084 KB | Time limit exceeded |
20 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 340 KB | Ok |
2 | Correct | 1 ms | 340 KB | Ok |
3 | Correct | 0 ms | 340 KB | Ok |
4 | Correct | 1 ms | 340 KB | Ok |
5 | Correct | 1 ms | 340 KB | Ok |
6 | Correct | 1 ms | 340 KB | Ok |
7 | Correct | 0 ms | 340 KB | Ok |
8 | Correct | 1 ms | 340 KB | Ok |
9 | Correct | 1 ms | 340 KB | Ok |
10 | Correct | 1 ms | 340 KB | Ok |
11 | Correct | 1 ms | 340 KB | Ok |
12 | Correct | 0 ms | 340 KB | Ok |
13 | Correct | 1 ms | 340 KB | Ok |
14 | Correct | 0 ms | 340 KB | Ok |
15 | Correct | 0 ms | 340 KB | Ok |
16 | Correct | 0 ms | 340 KB | Ok |
17 | Correct | 0 ms | 340 KB | Ok |
18 | Correct | 223 ms | 476 KB | Ok |
19 | Execution timed out | 2092 ms | 1084 KB | Time limit exceeded |
20 | Halted | 0 ms | 0 KB | - |