#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define pb emplace_back
#define AI(i) begin(i), end(i)
template<class T> bool chmin(T &a, T b) { return b < a && (a = b, true); }
template<class T> bool chmax(T &a, T b) { return a < b && (a = b, true); }
#ifdef KEV
#define DE(args...) kout("[ " + string(#args) + " ] = ", args)
void kout() { cerr << endl; }
template<class T, class ...U> void kout(T a, U ...b) { cerr << a << ' ', kout(b...); }
template<class T> void debug(T l, T r) { while (l != r) cerr << *l << " \n"[next(l)==r], ++l; }
#else
#define DE(...) 0
#define debug(...) 0
#endif
#include "Anna.h"
#include <vector>
namespace {
const int MAX_N = 200;
int res[MAX_N][MAX_N];
} // namespace
void Anna(int N, int K, std::vector<int> R, std::vector<int> C) {
for (int i = 0;i < N;++i) for (int j = 0;j < N;++j) {
res[i][j] = 0;
int A = 0, B = 0;
if (j % 3==0) A |= 1<<3;
int h = j % 3 * 3;
for (int l = h;l < h+3 && l < K;++l) {
if (R[l] <= i) A |= 1<<(l-h);
}
if (i % 3==0) B |= 1<<3;
h = i % 3 * 3;
for (int l = h;l < h+3 && l < K;++l) {
if (C[l] >= j) B |= 1<<(l-h);
}
// for (int l = 0;l < K;++l) {
// if (R[l] <= i) res[i][j] |= 1<<l;
// if (C[l] >= j) res[i][j] |= 1<<(l+K);
// }
DE(A, B);
res[i][j] = A + (B << 4) + 1;
}
for (int r = 0; r < N; r++) {
for (int c = 0; c < N; c++) {
SetFlag(r, c, res[r][c]);
}
}
cerr << "Done" << endl;
}
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define pb emplace_back
#define AI(i) begin(i), end(i)
namespace {
template<class T> bool chmin(T &a, T b) { return b < a && (a = b, true); }
template<class T> bool chmax(T &a, T b) { return a < b && (a = b, true); }
#ifdef KEV
#define DE(args...) kout("[ " + string(#args) + " ] = ", args)
void kout() { cerr << endl; }
template<class T, class ...U> void kout(T a, U ...b) { cerr << a << ' ', kout(b...); }
template<class T> void debug(T l, T r) { while (l != r) cerr << *l << " \n"[next(l)==r], ++l; }
#else
#define DE(...) 0
#define debug(...) 0
#endif
}
const int MAX_N = 300010;
#include "Bruno.h"
#include <vector>
namespace {
} // namespace
int get(int s, int a, int b, int c) {
DE(a, b, c);
a >>= s, b >>= s, c >>= s;
a &= 0b1111;
b &= 0b1111;
c &= 0b1111;
while (~a&(1<<3)) {
tie(a, b, c) = make_tuple(b, c, a);
}
a ^= (1<<3);
return (a | (b<<3) | (c<<6));
}
std::vector<int> Bruno(int K, std::vector<int> value) {
std::vector<int> res(K, 0);
for (int &i : value) --i;
int u0 = get(0,value[3], value[4], value[5]),
u1 = get(0,value[0], value[1], value[2]),
v0 = get(4,value[1], value[4], value[7]),
v1 = get(4,value[2], value[5], value[8]);
DE(u0, u1, v0, v1);
for (int i = 0; i < K; i++) {
if (u1&(1<<i))
res[i] = 3;
else if (v1&(1<<i))
res[i] = 0;
else if (~u0&(1<<i))
res[i] = 2;
else if (~v0&(1<<i))
res[i] = 1;
else res[i] = 4;
}
// if (value[1] & (1<<i)) {
// res[i] = 3;
// } else if (value[5] & (1<<(i+K))) {
// res[i] = 0;
// } else if (~value[4] & (1<<i)) {
// res[i] = 2;
// } else if (~value[4] & (1<<(i+K))) {
// res[i] = 1;
// } else res[i] = 4;
return res;
}
Compilation message
Anna.cpp: In function 'void Anna(int, int, std::vector<int>, std::vector<int>)':
Anna.cpp:14:17: warning: statement has no effect [-Wunused-value]
14 | #define DE(...) 0
| ^
Anna.cpp:56:3: note: in expansion of macro 'DE'
56 | DE(A, B);
| ^~
Bruno.cpp: In function 'int get(int, int, int, int)':
Bruno.cpp:16:17: warning: statement has no effect [-Wunused-value]
16 | #define DE(...) 0
| ^
Bruno.cpp:31:2: note: in expansion of macro 'DE'
31 | DE(a, b, c);
| ^~
Bruno.cpp: In function 'std::vector<int> Bruno(int, std::vector<int>)':
Bruno.cpp:16:17: warning: statement has no effect [-Wunused-value]
16 | #define DE(...) 0
| ^
Bruno.cpp:50:3: note: in expansion of macro 'DE'
50 | DE(u0, u1, v0, v1);
| ^~
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
11 ms |
468 KB |
Partially correct |
2 |
Partially correct |
16 ms |
384 KB |
Partially correct |
3 |
Partially correct |
13 ms |
384 KB |
Partially correct |
4 |
Partially correct |
18 ms |
384 KB |
Partially correct |
5 |
Partially correct |
16 ms |
388 KB |
Partially correct |
6 |
Partially correct |
16 ms |
384 KB |
Partially correct |
7 |
Partially correct |
19 ms |
448 KB |
Partially correct |
8 |
Partially correct |
20 ms |
384 KB |
Partially correct |
9 |
Partially correct |
24 ms |
384 KB |
Partially correct |
10 |
Partially correct |
17 ms |
384 KB |
Partially correct |
11 |
Partially correct |
17 ms |
384 KB |
Partially correct |
12 |
Partially correct |
17 ms |
472 KB |
Partially correct |
13 |
Partially correct |
22 ms |
384 KB |
Partially correct |
14 |
Partially correct |
19 ms |
472 KB |
Partially correct |
15 |
Partially correct |
16 ms |
384 KB |
Partially correct |
16 |
Partially correct |
16 ms |
384 KB |
Partially correct |
17 |
Partially correct |
18 ms |
384 KB |
Partially correct |
18 |
Partially correct |
25 ms |
384 KB |
Partially correct |
19 |
Partially correct |
18 ms |
472 KB |
Partially correct |
20 |
Partially correct |
16 ms |
384 KB |
Partially correct |
21 |
Partially correct |
19 ms |
500 KB |
Partially correct |
22 |
Partially correct |
16 ms |
388 KB |
Partially correct |
23 |
Partially correct |
19 ms |
384 KB |
Partially correct |
24 |
Partially correct |
13 ms |
388 KB |
Partially correct |
25 |
Partially correct |
14 ms |
468 KB |
Partially correct |
26 |
Partially correct |
22 ms |
388 KB |
Partially correct |
27 |
Partially correct |
15 ms |
384 KB |
Partially correct |
28 |
Partially correct |
20 ms |
388 KB |
Partially correct |
29 |
Partially correct |
18 ms |
384 KB |
Partially correct |
30 |
Partially correct |
18 ms |
384 KB |
Partially correct |
31 |
Partially correct |
16 ms |
388 KB |
Partially correct |
32 |
Partially correct |
18 ms |
384 KB |
Partially correct |
33 |
Partially correct |
23 ms |
384 KB |
Partially correct |
34 |
Partially correct |
18 ms |
384 KB |
Partially correct |
35 |
Partially correct |
19 ms |
384 KB |
Partially correct |
36 |
Partially correct |
15 ms |
468 KB |
Partially correct |
37 |
Partially correct |
16 ms |
384 KB |
Partially correct |
38 |
Partially correct |
19 ms |
388 KB |
Partially correct |
39 |
Partially correct |
16 ms |
384 KB |
Partially correct |
40 |
Partially correct |
22 ms |
384 KB |
Partially correct |
41 |
Partially correct |
16 ms |
384 KB |
Partially correct |
42 |
Partially correct |
18 ms |
384 KB |
Partially correct |
43 |
Partially correct |
19 ms |
384 KB |
Partially correct |
44 |
Partially correct |
19 ms |
384 KB |
Partially correct |
45 |
Partially correct |
19 ms |
388 KB |
Partially correct |
46 |
Partially correct |
19 ms |
448 KB |
Partially correct |
47 |
Partially correct |
16 ms |
388 KB |
Partially correct |
48 |
Partially correct |
22 ms |
384 KB |
Partially correct |
49 |
Partially correct |
19 ms |
384 KB |
Partially correct |
50 |
Partially correct |
17 ms |
388 KB |
Partially correct |
51 |
Partially correct |
22 ms |
388 KB |
Partially correct |
52 |
Partially correct |
19 ms |
388 KB |
Partially correct |
53 |
Partially correct |
20 ms |
384 KB |
Partially correct |
54 |
Partially correct |
20 ms |
384 KB |
Partially correct |
55 |
Partially correct |
24 ms |
384 KB |
Partially correct |
56 |
Partially correct |
27 ms |
384 KB |
Partially correct |
57 |
Partially correct |
22 ms |
384 KB |
Partially correct |
58 |
Partially correct |
24 ms |
384 KB |
Partially correct |
59 |
Partially correct |
22 ms |
384 KB |
Partially correct |
60 |
Partially correct |
19 ms |
388 KB |
Partially correct |
61 |
Partially correct |
26 ms |
384 KB |
Partially correct |
62 |
Partially correct |
18 ms |
388 KB |
Partially correct |
63 |
Partially correct |
23 ms |
388 KB |
Partially correct |
64 |
Partially correct |
26 ms |
384 KB |
Partially correct |
65 |
Partially correct |
21 ms |
384 KB |
Partially correct |
66 |
Partially correct |
23 ms |
468 KB |
Partially correct |
67 |
Partially correct |
26 ms |
384 KB |
Partially correct |
68 |
Partially correct |
25 ms |
384 KB |
Partially correct |
69 |
Partially correct |
28 ms |
388 KB |
Partially correct |
70 |
Partially correct |
18 ms |
512 KB |
Partially correct |
71 |
Partially correct |
24 ms |
384 KB |
Partially correct |
72 |
Partially correct |
27 ms |
384 KB |
Partially correct |
73 |
Partially correct |
22 ms |
384 KB |
Partially correct |
74 |
Partially correct |
20 ms |
384 KB |
Partially correct |
75 |
Partially correct |
23 ms |
384 KB |
Partially correct |
76 |
Partially correct |
27 ms |
464 KB |
Partially correct |
77 |
Partially correct |
23 ms |
384 KB |
Partially correct |
78 |
Partially correct |
27 ms |
384 KB |
Partially correct |
79 |
Partially correct |
26 ms |
384 KB |
Partially correct |
80 |
Partially correct |
27 ms |
384 KB |
Partially correct |
81 |
Partially correct |
23 ms |
388 KB |
Partially correct |
82 |
Partially correct |
22 ms |
384 KB |
Partially correct |
83 |
Partially correct |
22 ms |
384 KB |
Partially correct |
84 |
Partially correct |
23 ms |
384 KB |
Partially correct |
85 |
Partially correct |
27 ms |
464 KB |
Partially correct |
86 |
Partially correct |
20 ms |
384 KB |
Partially correct |
87 |
Partially correct |
25 ms |
384 KB |
Partially correct |
88 |
Partially correct |
22 ms |
384 KB |
Partially correct |
89 |
Partially correct |
29 ms |
384 KB |
Partially correct |
90 |
Partially correct |
20 ms |
384 KB |
Partially correct |
91 |
Partially correct |
20 ms |
392 KB |
Partially correct |
92 |
Partially correct |
22 ms |
388 KB |
Partially correct |
93 |
Partially correct |
22 ms |
384 KB |
Partially correct |
94 |
Partially correct |
22 ms |
464 KB |
Partially correct |
95 |
Partially correct |
28 ms |
384 KB |
Partially correct |
96 |
Partially correct |
23 ms |
384 KB |
Partially correct |
97 |
Partially correct |
22 ms |
424 KB |
Partially correct |
98 |
Partially correct |
20 ms |
384 KB |
Partially correct |
99 |
Partially correct |
26 ms |
384 KB |
Partially correct |
100 |
Partially correct |
23 ms |
384 KB |
Partially correct |
101 |
Partially correct |
22 ms |
384 KB |
Partially correct |
102 |
Partially correct |
24 ms |
384 KB |
Partially correct |
103 |
Partially correct |
20 ms |
384 KB |
Partially correct |
104 |
Partially correct |
22 ms |
384 KB |
Partially correct |
105 |
Partially correct |
23 ms |
384 KB |
Partially correct |
106 |
Partially correct |
22 ms |
384 KB |
Partially correct |
107 |
Partially correct |
18 ms |
384 KB |
Partially correct |
108 |
Partially correct |
26 ms |
384 KB |
Partially correct |
109 |
Partially correct |
24 ms |
384 KB |
Partially correct |
110 |
Partially correct |
20 ms |
384 KB |
Partially correct |
111 |
Partially correct |
25 ms |
384 KB |
Partially correct |
112 |
Partially correct |
26 ms |
388 KB |
Partially correct |
113 |
Partially correct |
20 ms |
392 KB |
Partially correct |
114 |
Partially correct |
19 ms |
384 KB |
Partially correct |
115 |
Partially correct |
31 ms |
384 KB |
Partially correct |
116 |
Partially correct |
23 ms |
388 KB |
Partially correct |
117 |
Partially correct |
23 ms |
384 KB |
Partially correct |
118 |
Partially correct |
21 ms |
448 KB |
Partially correct |
119 |
Partially correct |
26 ms |
384 KB |
Partially correct |
120 |
Partially correct |
833 ms |
624 KB |
Partially correct |
121 |
Partially correct |
827 ms |
756 KB |
Partially correct |
122 |
Partially correct |
777 ms |
680 KB |
Partially correct |
123 |
Partially correct |
802 ms |
740 KB |
Partially correct |
124 |
Partially correct |
864 ms |
712 KB |
Partially correct |
125 |
Partially correct |
767 ms |
628 KB |
Partially correct |
126 |
Partially correct |
873 ms |
672 KB |
Partially correct |
127 |
Partially correct |
829 ms |
688 KB |
Partially correct |
128 |
Partially correct |
750 ms |
700 KB |
Partially correct |
129 |
Partially correct |
839 ms |
756 KB |
Partially correct |
130 |
Partially correct |
844 ms |
804 KB |
Partially correct |
131 |
Partially correct |
831 ms |
828 KB |
Partially correct |
132 |
Partially correct |
913 ms |
788 KB |
Partially correct |
133 |
Partially correct |
845 ms |
872 KB |
Partially correct |
134 |
Partially correct |
784 ms |
864 KB |
Partially correct |
135 |
Partially correct |
824 ms |
836 KB |
Partially correct |
136 |
Partially correct |
971 ms |
816 KB |
Partially correct |
137 |
Partially correct |
856 ms |
836 KB |
Partially correct |
138 |
Partially correct |
840 ms |
808 KB |
Partially correct |
139 |
Partially correct |
859 ms |
832 KB |
Partially correct |
140 |
Partially correct |
800 ms |
796 KB |
Partially correct |
141 |
Partially correct |
862 ms |
748 KB |
Partially correct |
142 |
Partially correct |
780 ms |
840 KB |
Partially correct |
143 |
Partially correct |
807 ms |
724 KB |
Partially correct |
144 |
Partially correct |
826 ms |
708 KB |
Partially correct |
145 |
Partially correct |
873 ms |
632 KB |
Partially correct |
146 |
Partially correct |
808 ms |
736 KB |
Partially correct |
147 |
Partially correct |
801 ms |
676 KB |
Partially correct |
148 |
Partially correct |
857 ms |
768 KB |
Partially correct |
149 |
Partially correct |
859 ms |
700 KB |
Partially correct |
150 |
Partially correct |
857 ms |
760 KB |
Partially correct |
151 |
Partially correct |
825 ms |
852 KB |
Partially correct |
152 |
Partially correct |
870 ms |
688 KB |
Partially correct |
153 |
Partially correct |
829 ms |
892 KB |
Partially correct |
154 |
Partially correct |
780 ms |
688 KB |
Partially correct |
155 |
Partially correct |
794 ms |
908 KB |
Partially correct |
156 |
Partially correct |
876 ms |
656 KB |
Partially correct |
157 |
Partially correct |
784 ms |
912 KB |
Partially correct |
158 |
Partially correct |
754 ms |
792 KB |
Partially correct |
159 |
Partially correct |
846 ms |
776 KB |
Partially correct |
160 |
Partially correct |
862 ms |
672 KB |
Partially correct |
161 |
Partially correct |
765 ms |
900 KB |
Partially correct |
162 |
Partially correct |
771 ms |
808 KB |
Partially correct |
163 |
Partially correct |
823 ms |
664 KB |
Partially correct |
164 |
Partially correct |
789 ms |
780 KB |
Partially correct |
165 |
Partially correct |
789 ms |
872 KB |
Partially correct |
166 |
Partially correct |
780 ms |
800 KB |
Partially correct |
167 |
Partially correct |
791 ms |
828 KB |
Partially correct |
168 |
Partially correct |
770 ms |
796 KB |
Partially correct |
169 |
Partially correct |
825 ms |
832 KB |
Partially correct |
170 |
Partially correct |
800 ms |
788 KB |
Partially correct |
171 |
Partially correct |
766 ms |
688 KB |
Partially correct |
172 |
Partially correct |
855 ms |
768 KB |
Partially correct |
173 |
Partially correct |
770 ms |
784 KB |
Partially correct |
174 |
Partially correct |
825 ms |
804 KB |
Partially correct |
175 |
Partially correct |
822 ms |
772 KB |
Partially correct |
176 |
Partially correct |
832 ms |
704 KB |
Partially correct |
177 |
Partially correct |
821 ms |
708 KB |
Partially correct |
178 |
Partially correct |
906 ms |
744 KB |
Partially correct |
179 |
Partially correct |
983 ms |
752 KB |
Partially correct |
180 |
Partially correct |
792 ms |
796 KB |
Partially correct |
181 |
Partially correct |
766 ms |
688 KB |
Partially correct |
182 |
Partially correct |
771 ms |
684 KB |
Partially correct |
183 |
Partially correct |
766 ms |
808 KB |
Partially correct |
184 |
Partially correct |
835 ms |
728 KB |
Partially correct |
185 |
Partially correct |
827 ms |
688 KB |
Partially correct |
186 |
Partially correct |
772 ms |
676 KB |
Partially correct |
187 |
Partially correct |
786 ms |
840 KB |
Partially correct |
188 |
Partially correct |
828 ms |
816 KB |
Partially correct |
189 |
Partially correct |
767 ms |
756 KB |
Partially correct |
190 |
Partially correct |
776 ms |
864 KB |
Partially correct |
191 |
Partially correct |
835 ms |
780 KB |
Partially correct |
192 |
Partially correct |
801 ms |
836 KB |
Partially correct |
193 |
Partially correct |
770 ms |
780 KB |
Partially correct |
194 |
Partially correct |
807 ms |
584 KB |
Partially correct |
195 |
Partially correct |
786 ms |
604 KB |
Partially correct |
196 |
Partially correct |
840 ms |
728 KB |
Partially correct |
197 |
Partially correct |
760 ms |
760 KB |
Partially correct |
198 |
Partially correct |
797 ms |
776 KB |
Partially correct |
199 |
Partially correct |
891 ms |
692 KB |
Partially correct |
200 |
Partially correct |
805 ms |
792 KB |
Partially correct |
201 |
Partially correct |
808 ms |
688 KB |
Partially correct |
202 |
Partially correct |
808 ms |
680 KB |
Partially correct |
203 |
Partially correct |
863 ms |
752 KB |
Partially correct |
204 |
Partially correct |
816 ms |
800 KB |
Partially correct |
205 |
Partially correct |
854 ms |
764 KB |
Partially correct |
206 |
Partially correct |
1043 ms |
612 KB |
Partially correct |
207 |
Partially correct |
912 ms |
616 KB |
Partially correct |
208 |
Partially correct |
880 ms |
692 KB |
Partially correct |
209 |
Partially correct |
811 ms |
704 KB |
Partially correct |
210 |
Partially correct |
604 ms |
748 KB |
Partially correct |
211 |
Partially correct |
698 ms |
868 KB |
Partially correct |
212 |
Partially correct |
613 ms |
792 KB |
Partially correct |
213 |
Partially correct |
756 ms |
724 KB |
Partially correct |
214 |
Partially correct |
689 ms |
836 KB |
Partially correct |
215 |
Partially correct |
644 ms |
712 KB |
Partially correct |
216 |
Partially correct |
639 ms |
708 KB |
Partially correct |
217 |
Partially correct |
594 ms |
764 KB |
Partially correct |
218 |
Partially correct |
611 ms |
748 KB |
Partially correct |
219 |
Partially correct |
597 ms |
808 KB |
Partially correct |
220 |
Partially correct |
614 ms |
676 KB |
Partially correct |
221 |
Partially correct |
602 ms |
740 KB |
Partially correct |
222 |
Partially correct |
603 ms |
692 KB |
Partially correct |
223 |
Partially correct |
706 ms |
696 KB |
Partially correct |
224 |
Partially correct |
749 ms |
604 KB |
Partially correct |
225 |
Partially correct |
609 ms |
624 KB |
Partially correct |
226 |
Partially correct |
618 ms |
668 KB |
Partially correct |