#include "Anna.h"
#include <bits/stdc++.h>
using namespace std;
using ii = pair<int, int>;
using ll = long long;
using vll = vector<ll>;
using vi = vector<int>;
#define fi first
#define se second
#define all(v) begin(v), end(v)
#define sz(v) (int)(v.size())
#ifndef LOCAL
#define debug(...)
#endif
namespace {
#ifdef LOCAL
template<typename T>
string to_string(T x) {
return std::to_string(x);
}
template<typename A, typename B>
string to_string(pair<A, B> pa) {
return "(" + to_string(pa.first) + "," + to_string(pa.second) + ")";
}
string to_string(string s) {
return "\"" + s + "\"";
}
template<typename T>
string to_string(vector<T> v) {
bool first = true;
string ret = "{";
for(int i = 0; i < (int)v.size(); ++i) {
if(!first) ret += ", ";
ret += to_string(v[i]);
first = false;
}
ret += "}";
return ret;
}
void debug_out() {
cerr << endl;
}
template<typename Head, typename... Tail>
void debug_out(Head _H_, Tail... _T_) {
cerr << " " << to_string(_H_);
debug_out(_T_...);
}
#define debug(...) cerr << "[" << #__VA_ARGS__ << "]:", debug_out(__VA_ARGS__)
#else
#define debug(...)
#endif
const int neix[] = {-1, -1, -1, 0, 0, 0, +1, +1, +1};
const int neiy[] = {-1, 0, +1, -1, 0, +1, -1, 0, +1};
int get_action(int x1, int y1, int x2, int y2) {
if(x1 == x2 and y1 == y2) return 4;
if(x2 <= x1 and y2 <= y1) {
if(x1 - x2 >= y1 - y2) return 3;
return 1;
}
if(x2 <= x1 and y2 > y1) {
if(x1 - x2 >= y2 - y1) return 3;
return 0;
}
if(x2 > x1 and y2 <= y1) {
if(x2 - x1 >= y1 - y2) return 2;
return 1;
}
if(x2 > x1 and y2 > y1) {
if(x2 - x1 >= y2 - y1) return 2;
return 0;
}
}
} // namespace
void Anna(int N, int K, std::vector<int> R, std::vector<int> C) {
for(int r = 0; r < N; ++r) {
for(int c = 0; c < N; ++c) {
int k = 3 * (r % 3) + c % 3;
debug(r, c, k);
int value = 0;
if(k < K) {
if(max(abs(R[k] - r), abs(C[k] - c)) <= 1) {
for(int i = 0; i < 9; ++i) {
if(R[k] - r == neix[i] and C[k] - c == neiy[i]) {
value = i;
}
}
} else {
value = get_action(r, c, R[k], C[k]) + 9;
}
} else if(k == 8) {
value = 13;
}
SetFlag(r, c, value + 1);
}
}
}
#include "Bruno.h"
#include <bits/stdc++.h>
using namespace std;
using ii = pair<int, int>;
using ll = long long;
using vll = vector<ll>;
using vi = vector<int>;
#define fi first
#define se second
#define all(v) begin(v), end(v)
#define sz(v) (int)(v.size())
namespace {
#ifdef LOCAL
template<typename T>
string to_string(T x) {
return std::to_string(x);
}
template<typename A, typename B>
string to_string(pair<A, B> pa) {
return "(" + to_string(pa.first) + "," + to_string(pa.second) + ")";
}
string to_string(string s) {
return "\"" + s + "\"";
}
template<typename T>
string to_string(vector<T> v) {
bool first = true;
string ret = "{";
for(int i = 0; i < (int)v.size(); ++i) {
if(!first) ret += ", ";
ret += to_string(v[i]);
first = false;
}
ret += "}";
return ret;
}
void debug_out() {
cerr << endl;
}
template<typename Head, typename... Tail>
void debug_out(Head _H_, Tail... _T_) {
cerr << " " << to_string(_H_);
debug_out(_T_...);
}
#define debug(...) cerr << "[" << #__VA_ARGS__ << "]:", debug_out(__VA_ARGS__)
#else
#define debug(...)
#endif
const int neix[] = {-1, -1, -1, 0, 0, 0, +1, +1, +1};
const int neiy[] = {-1, 0, +1, -1, 0, +1, -1, 0, +1};
int get_action(int x1, int y1, int x2, int y2) {
if(x1 == x2 and y1 == y2) return 4;
if(x2 <= x1 and y2 <= y1) {
if(x1 - x2 >= y1 - y2) return 3;
return 1;
}
if(x2 <= x1 and y2 > y1) {
if(x1 - x2 >= y2 - y1) return 3;
return 0;
}
if(x2 > x1 and y2 <= y1) {
if(x2 - x1 >= y1 - y2) return 2;
return 1;
}
if(x2 > x1 and y2 > y1) {
if(x2 - x1 >= y2 - y1) return 2;
return 0;
}
}
} // namespace
vi Bruno(int K, vi value) {
for(int& x : value) x--;
int pivot = -1;
for(int i = 0; i < 9; ++i) {
if(value[i] == 13) {
pivot = i;
}
}
assert(~pivot);
vi ans(K, -1);
for(int i = 0; i < 9; ++i) {
int modx = (6 + 2 + neix[i] - neix[pivot]) % 3;
int mody = (6 + 2 + neiy[i] - neiy[pivot]) % 3;
int k = modx * 3 + mody;
debug(modx, mody, k);
if(k < K) {
int number = value[i];
if(number >= 9) {
ans[k] = number - 9;
} else {
ans[k] = get_action(0, 0, neix[i] + neix[number], neiy[i] + neiy[number]);
}
debug(ans[k]);
}
}
assert(count(all(ans), -1) == 0);
return ans;
}
Compilation message
Anna.cpp: In function 'int {anonymous}::get_action(int, int, int, int)':
Anna.cpp:80:3: warning: control reaches end of non-void function [-Wreturn-type]
80 | }
| ^
Bruno.cpp: In function 'int {anonymous}::get_action(int, int, int, int)':
Bruno.cpp:76:3: warning: control reaches end of non-void function [-Wreturn-type]
76 | }
| ^
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
9 ms |
472 KB |
Partially correct |
2 |
Partially correct |
10 ms |
384 KB |
Partially correct |
3 |
Partially correct |
12 ms |
388 KB |
Partially correct |
4 |
Partially correct |
14 ms |
384 KB |
Partially correct |
5 |
Partially correct |
13 ms |
384 KB |
Partially correct |
6 |
Partially correct |
15 ms |
384 KB |
Partially correct |
7 |
Partially correct |
12 ms |
384 KB |
Partially correct |
8 |
Partially correct |
12 ms |
384 KB |
Partially correct |
9 |
Partially correct |
14 ms |
384 KB |
Partially correct |
10 |
Partially correct |
12 ms |
460 KB |
Partially correct |
11 |
Partially correct |
13 ms |
388 KB |
Partially correct |
12 |
Partially correct |
11 ms |
384 KB |
Partially correct |
13 |
Partially correct |
13 ms |
384 KB |
Partially correct |
14 |
Partially correct |
11 ms |
388 KB |
Partially correct |
15 |
Partially correct |
12 ms |
384 KB |
Partially correct |
16 |
Partially correct |
12 ms |
384 KB |
Partially correct |
17 |
Partially correct |
11 ms |
384 KB |
Partially correct |
18 |
Partially correct |
13 ms |
384 KB |
Partially correct |
19 |
Partially correct |
12 ms |
384 KB |
Partially correct |
20 |
Partially correct |
12 ms |
384 KB |
Partially correct |
21 |
Partially correct |
15 ms |
384 KB |
Partially correct |
22 |
Partially correct |
15 ms |
384 KB |
Partially correct |
23 |
Partially correct |
12 ms |
384 KB |
Partially correct |
24 |
Partially correct |
10 ms |
464 KB |
Partially correct |
25 |
Partially correct |
11 ms |
384 KB |
Partially correct |
26 |
Partially correct |
13 ms |
384 KB |
Partially correct |
27 |
Partially correct |
13 ms |
384 KB |
Partially correct |
28 |
Partially correct |
11 ms |
468 KB |
Partially correct |
29 |
Partially correct |
12 ms |
388 KB |
Partially correct |
30 |
Partially correct |
14 ms |
384 KB |
Partially correct |
31 |
Partially correct |
13 ms |
384 KB |
Partially correct |
32 |
Partially correct |
13 ms |
384 KB |
Partially correct |
33 |
Partially correct |
13 ms |
384 KB |
Partially correct |
34 |
Partially correct |
12 ms |
384 KB |
Partially correct |
35 |
Partially correct |
11 ms |
384 KB |
Partially correct |
36 |
Partially correct |
15 ms |
384 KB |
Partially correct |
37 |
Partially correct |
13 ms |
384 KB |
Partially correct |
38 |
Partially correct |
16 ms |
456 KB |
Partially correct |
39 |
Partially correct |
11 ms |
472 KB |
Partially correct |
40 |
Partially correct |
11 ms |
384 KB |
Partially correct |
41 |
Partially correct |
13 ms |
388 KB |
Partially correct |
42 |
Partially correct |
16 ms |
384 KB |
Partially correct |
43 |
Partially correct |
12 ms |
388 KB |
Partially correct |
44 |
Partially correct |
11 ms |
476 KB |
Partially correct |
45 |
Partially correct |
15 ms |
384 KB |
Partially correct |
46 |
Partially correct |
12 ms |
384 KB |
Partially correct |
47 |
Partially correct |
15 ms |
384 KB |
Partially correct |
48 |
Partially correct |
18 ms |
384 KB |
Partially correct |
49 |
Partially correct |
13 ms |
468 KB |
Partially correct |
50 |
Partially correct |
16 ms |
384 KB |
Partially correct |
51 |
Partially correct |
14 ms |
384 KB |
Partially correct |
52 |
Partially correct |
13 ms |
384 KB |
Partially correct |
53 |
Partially correct |
13 ms |
388 KB |
Partially correct |
54 |
Partially correct |
14 ms |
384 KB |
Partially correct |
55 |
Partially correct |
13 ms |
384 KB |
Partially correct |
56 |
Partially correct |
17 ms |
384 KB |
Partially correct |
57 |
Partially correct |
18 ms |
388 KB |
Partially correct |
58 |
Partially correct |
19 ms |
384 KB |
Partially correct |
59 |
Partially correct |
15 ms |
384 KB |
Partially correct |
60 |
Partially correct |
17 ms |
384 KB |
Partially correct |
61 |
Partially correct |
19 ms |
384 KB |
Partially correct |
62 |
Partially correct |
17 ms |
384 KB |
Partially correct |
63 |
Partially correct |
17 ms |
384 KB |
Partially correct |
64 |
Partially correct |
16 ms |
384 KB |
Partially correct |
65 |
Partially correct |
17 ms |
384 KB |
Partially correct |
66 |
Partially correct |
16 ms |
384 KB |
Partially correct |
67 |
Partially correct |
15 ms |
472 KB |
Partially correct |
68 |
Partially correct |
18 ms |
388 KB |
Partially correct |
69 |
Partially correct |
16 ms |
384 KB |
Partially correct |
70 |
Partially correct |
21 ms |
384 KB |
Partially correct |
71 |
Partially correct |
17 ms |
392 KB |
Partially correct |
72 |
Partially correct |
16 ms |
472 KB |
Partially correct |
73 |
Partially correct |
15 ms |
468 KB |
Partially correct |
74 |
Partially correct |
21 ms |
384 KB |
Partially correct |
75 |
Partially correct |
19 ms |
384 KB |
Partially correct |
76 |
Partially correct |
21 ms |
384 KB |
Partially correct |
77 |
Partially correct |
19 ms |
384 KB |
Partially correct |
78 |
Partially correct |
15 ms |
384 KB |
Partially correct |
79 |
Partially correct |
20 ms |
384 KB |
Partially correct |
80 |
Partially correct |
18 ms |
384 KB |
Partially correct |
81 |
Partially correct |
16 ms |
388 KB |
Partially correct |
82 |
Partially correct |
17 ms |
468 KB |
Partially correct |
83 |
Partially correct |
20 ms |
384 KB |
Partially correct |
84 |
Partially correct |
16 ms |
384 KB |
Partially correct |
85 |
Partially correct |
16 ms |
388 KB |
Partially correct |
86 |
Partially correct |
18 ms |
468 KB |
Partially correct |
87 |
Partially correct |
16 ms |
384 KB |
Partially correct |
88 |
Partially correct |
16 ms |
388 KB |
Partially correct |
89 |
Partially correct |
20 ms |
384 KB |
Partially correct |
90 |
Partially correct |
15 ms |
384 KB |
Partially correct |
91 |
Partially correct |
17 ms |
384 KB |
Partially correct |
92 |
Partially correct |
16 ms |
384 KB |
Partially correct |
93 |
Partially correct |
16 ms |
388 KB |
Partially correct |
94 |
Partially correct |
15 ms |
384 KB |
Partially correct |
95 |
Partially correct |
16 ms |
384 KB |
Partially correct |
96 |
Partially correct |
17 ms |
384 KB |
Partially correct |
97 |
Partially correct |
17 ms |
384 KB |
Partially correct |
98 |
Partially correct |
20 ms |
384 KB |
Partially correct |
99 |
Partially correct |
19 ms |
384 KB |
Partially correct |
100 |
Partially correct |
16 ms |
388 KB |
Partially correct |
101 |
Partially correct |
20 ms |
384 KB |
Partially correct |
102 |
Partially correct |
20 ms |
388 KB |
Partially correct |
103 |
Partially correct |
20 ms |
472 KB |
Partially correct |
104 |
Partially correct |
16 ms |
384 KB |
Partially correct |
105 |
Partially correct |
16 ms |
384 KB |
Partially correct |
106 |
Partially correct |
21 ms |
384 KB |
Partially correct |
107 |
Partially correct |
17 ms |
384 KB |
Partially correct |
108 |
Partially correct |
17 ms |
384 KB |
Partially correct |
109 |
Partially correct |
20 ms |
384 KB |
Partially correct |
110 |
Partially correct |
16 ms |
384 KB |
Partially correct |
111 |
Partially correct |
18 ms |
384 KB |
Partially correct |
112 |
Partially correct |
16 ms |
384 KB |
Partially correct |
113 |
Partially correct |
21 ms |
388 KB |
Partially correct |
114 |
Partially correct |
16 ms |
384 KB |
Partially correct |
115 |
Partially correct |
19 ms |
388 KB |
Partially correct |
116 |
Partially correct |
20 ms |
388 KB |
Partially correct |
117 |
Partially correct |
19 ms |
384 KB |
Partially correct |
118 |
Partially correct |
21 ms |
384 KB |
Partially correct |
119 |
Partially correct |
17 ms |
384 KB |
Partially correct |
120 |
Partially correct |
713 ms |
516 KB |
Partially correct |
121 |
Partially correct |
657 ms |
672 KB |
Partially correct |
122 |
Partially correct |
741 ms |
632 KB |
Partially correct |
123 |
Partially correct |
685 ms |
524 KB |
Partially correct |
124 |
Partially correct |
685 ms |
728 KB |
Partially correct |
125 |
Partially correct |
717 ms |
580 KB |
Partially correct |
126 |
Partially correct |
656 ms |
884 KB |
Partially correct |
127 |
Partially correct |
690 ms |
712 KB |
Partially correct |
128 |
Partially correct |
675 ms |
692 KB |
Partially correct |
129 |
Partially correct |
681 ms |
668 KB |
Partially correct |
130 |
Partially correct |
685 ms |
608 KB |
Partially correct |
131 |
Partially correct |
686 ms |
788 KB |
Partially correct |
132 |
Partially correct |
686 ms |
600 KB |
Partially correct |
133 |
Partially correct |
688 ms |
712 KB |
Partially correct |
134 |
Partially correct |
652 ms |
692 KB |
Partially correct |
135 |
Partially correct |
665 ms |
872 KB |
Partially correct |
136 |
Partially correct |
683 ms |
648 KB |
Partially correct |
137 |
Partially correct |
672 ms |
632 KB |
Partially correct |
138 |
Partially correct |
667 ms |
716 KB |
Partially correct |
139 |
Partially correct |
658 ms |
808 KB |
Partially correct |
140 |
Partially correct |
656 ms |
548 KB |
Partially correct |
141 |
Partially correct |
660 ms |
680 KB |
Partially correct |
142 |
Partially correct |
666 ms |
668 KB |
Partially correct |
143 |
Partially correct |
666 ms |
628 KB |
Partially correct |
144 |
Partially correct |
666 ms |
696 KB |
Partially correct |
145 |
Partially correct |
655 ms |
600 KB |
Partially correct |
146 |
Partially correct |
699 ms |
516 KB |
Partially correct |
147 |
Partially correct |
659 ms |
620 KB |
Partially correct |
148 |
Partially correct |
693 ms |
716 KB |
Partially correct |
149 |
Partially correct |
679 ms |
680 KB |
Partially correct |
150 |
Partially correct |
660 ms |
684 KB |
Partially correct |
151 |
Partially correct |
667 ms |
736 KB |
Partially correct |
152 |
Partially correct |
682 ms |
516 KB |
Partially correct |
153 |
Partially correct |
660 ms |
532 KB |
Partially correct |
154 |
Partially correct |
681 ms |
672 KB |
Partially correct |
155 |
Partially correct |
685 ms |
652 KB |
Partially correct |
156 |
Partially correct |
672 ms |
764 KB |
Partially correct |
157 |
Partially correct |
662 ms |
684 KB |
Partially correct |
158 |
Partially correct |
666 ms |
640 KB |
Partially correct |
159 |
Partially correct |
696 ms |
580 KB |
Partially correct |
160 |
Partially correct |
668 ms |
604 KB |
Partially correct |
161 |
Partially correct |
668 ms |
724 KB |
Partially correct |
162 |
Partially correct |
707 ms |
628 KB |
Partially correct |
163 |
Partially correct |
691 ms |
836 KB |
Partially correct |
164 |
Partially correct |
720 ms |
636 KB |
Partially correct |
165 |
Partially correct |
693 ms |
596 KB |
Partially correct |
166 |
Partially correct |
730 ms |
788 KB |
Partially correct |
167 |
Partially correct |
674 ms |
688 KB |
Partially correct |
168 |
Partially correct |
720 ms |
624 KB |
Partially correct |
169 |
Partially correct |
666 ms |
592 KB |
Partially correct |
170 |
Partially correct |
745 ms |
804 KB |
Partially correct |
171 |
Partially correct |
652 ms |
608 KB |
Partially correct |
172 |
Partially correct |
659 ms |
632 KB |
Partially correct |
173 |
Partially correct |
694 ms |
748 KB |
Partially correct |
174 |
Partially correct |
677 ms |
720 KB |
Partially correct |
175 |
Partially correct |
731 ms |
612 KB |
Partially correct |
176 |
Partially correct |
659 ms |
816 KB |
Partially correct |
177 |
Partially correct |
656 ms |
808 KB |
Partially correct |
178 |
Partially correct |
655 ms |
572 KB |
Partially correct |
179 |
Partially correct |
657 ms |
720 KB |
Partially correct |
180 |
Partially correct |
711 ms |
756 KB |
Partially correct |
181 |
Partially correct |
662 ms |
644 KB |
Partially correct |
182 |
Partially correct |
666 ms |
508 KB |
Partially correct |
183 |
Partially correct |
672 ms |
544 KB |
Partially correct |
184 |
Partially correct |
693 ms |
600 KB |
Partially correct |
185 |
Partially correct |
669 ms |
624 KB |
Partially correct |
186 |
Partially correct |
685 ms |
652 KB |
Partially correct |
187 |
Partially correct |
676 ms |
628 KB |
Partially correct |
188 |
Partially correct |
711 ms |
600 KB |
Partially correct |
189 |
Partially correct |
690 ms |
612 KB |
Partially correct |
190 |
Partially correct |
767 ms |
716 KB |
Partially correct |
191 |
Partially correct |
683 ms |
548 KB |
Partially correct |
192 |
Partially correct |
667 ms |
564 KB |
Partially correct |
193 |
Partially correct |
701 ms |
604 KB |
Partially correct |
194 |
Partially correct |
716 ms |
660 KB |
Partially correct |
195 |
Partially correct |
671 ms |
604 KB |
Partially correct |
196 |
Partially correct |
661 ms |
604 KB |
Partially correct |
197 |
Partially correct |
654 ms |
656 KB |
Partially correct |
198 |
Partially correct |
703 ms |
692 KB |
Partially correct |
199 |
Partially correct |
679 ms |
672 KB |
Partially correct |
200 |
Partially correct |
703 ms |
636 KB |
Partially correct |
201 |
Partially correct |
662 ms |
740 KB |
Partially correct |
202 |
Partially correct |
676 ms |
628 KB |
Partially correct |
203 |
Partially correct |
677 ms |
620 KB |
Partially correct |
204 |
Partially correct |
657 ms |
664 KB |
Partially correct |
205 |
Partially correct |
661 ms |
676 KB |
Partially correct |
206 |
Partially correct |
671 ms |
696 KB |
Partially correct |
207 |
Partially correct |
679 ms |
544 KB |
Partially correct |
208 |
Partially correct |
691 ms |
704 KB |
Partially correct |
209 |
Partially correct |
674 ms |
724 KB |
Partially correct |
210 |
Partially correct |
554 ms |
664 KB |
Partially correct |
211 |
Partially correct |
496 ms |
592 KB |
Partially correct |
212 |
Partially correct |
521 ms |
676 KB |
Partially correct |
213 |
Partially correct |
533 ms |
832 KB |
Partially correct |
214 |
Partially correct |
514 ms |
680 KB |
Partially correct |
215 |
Partially correct |
497 ms |
512 KB |
Partially correct |
216 |
Partially correct |
509 ms |
628 KB |
Partially correct |
217 |
Partially correct |
509 ms |
516 KB |
Partially correct |
218 |
Partially correct |
518 ms |
608 KB |
Partially correct |
219 |
Partially correct |
510 ms |
620 KB |
Partially correct |
220 |
Partially correct |
551 ms |
612 KB |
Partially correct |
221 |
Partially correct |
501 ms |
632 KB |
Partially correct |
222 |
Partially correct |
504 ms |
648 KB |
Partially correct |
223 |
Partially correct |
515 ms |
644 KB |
Partially correct |
224 |
Partially correct |
534 ms |
620 KB |
Partially correct |
225 |
Partially correct |
495 ms |
588 KB |
Partially correct |
226 |
Partially correct |
516 ms |
588 KB |
Partially correct |