#include "Anna.h"
#include<bits/stdc++.h>
using namespace std;
//#define int long long
#define fi first
#define se second
#define pb push_back
#define mp make_pair
typedef pair<int, int> ii;
typedef pair<ii, int> iii;
typedef pair<ii, ii> iiii;
const int N = 3e5 + 5;
const int oo = 1e18 + 7, mod = 1e9 + 7;
int n, a[N];
void Anna(int N, int K, vector<int> r, vector<int> c){
for(int ii = 0; ii < 3; ii++){
for(int jj = 0; jj < 3; jj++){
bool ck = 1;
for(int i = 0; i < N; i++){
for(int j = 0; j < N; j++){
int temp = (((i + ii) % 3) * 3 + ((j + jj) % 3));
if(temp == 8){
//SetFlag(i, j, 1);
//mx = max(mx, 1);
continue;
}
else if(temp == 7){
//mx = max(mx, 2);
//SetFlag(i, j, 2);
continue;
}
else{
//cout << i << " " << j << " " << r[temp] << " " << c[temp] << "\n";
int pos1 = r[temp], pos2 = c[temp];
int diff1 = r[temp] - i;
int diff2 = c[temp] - j;
ck &= (diff1 != 0 || diff2 != 0);
}
}
}
if(!ck) continue;
for(int i = 0; i < N; i++){
for(int j = 0; j < N; j++){
int temp = (((i + ii) % 3) * 3 + ((j + jj) % 3));
if(temp == 8){
SetFlag(i, j, 1);
continue;
}
else if(temp == 7){
SetFlag(i, j, 2);
continue;
}
else{
//cout << i << " " << j << " " << r[temp] << " " << c[temp] << "\n";
int pos1 = r[temp], pos2 = c[temp];
int diff1 = r[temp] - i;
int diff2 = c[temp] - j;
if(diff1 <= -2) SetFlag(i, j, 5);
else if(diff1 >= 2) SetFlag(i, j, 4);
else if(diff2 <= -2) SetFlag(i, j, 3);
else if(diff2 >= 2) SetFlag(i, j, 2);
else{
int x = (diff1 + 1) * 3 + diff2 + 1;
assert(x != 4);
if(x <= 3) SetFlag(i, j, 6 + x);
else SetFlag(i, j, 5 + x);
}
}
}
}
return;
}
}
}
/*
signed main(){
ios_base::sync_with_stdio(0);
int t;
cin >> t;
while(t--) process();
}*/
#include "Bruno.h"
#include<bits/stdc++.h>
using namespace std;
//#define int long long
#define fi first
#define se second
#define pb push_back
#define mp make_pair
typedef pair<int, int> ii;
typedef pair<ii, int> iii;
typedef pair<ii, ii> iiii;
const int N = 3e5 + 5;
const int oo = 1e18 + 7, mod = 1e9 + 7;
int arr1[] = {-1, -1, -1, 0, 0, 1, 1, 1};
int arr2[] = {-1, 0, 1, -1, 1, -1, 0, 1};
vector<int> Bruno(int K, vector<int> values){
vector<int> dirs;
dirs.resize(K);
int pos = -1;
//for(int i = 0; i < 9; i++) cout << values[i] << " ";
//cout << "\n";
for(int i = 0; i < 9; i++){
if(values[i] == 1){
pos = i;
break;
}
}
int pos1 = (pos / 3) - 1, pos2 = (pos % 3) - 1;
int posi = -1;
for(int i = 1; i <= 3; i++){
for(int j = 1; j <= 3; j++){
int pos3 = pos1 + i, pos4 = pos2 + j;
while(pos3 >= 2) pos3 -= 3;
while(pos4 >= 2) pos4 -= 3;
posi++;
//cout << pos3 << " " << pos4 << " " << posi << "\n";
if(posi == 7) break;
int x = values[(pos3 + 1) * 3 + pos4 + 1];
//cout << x << "\n";
if(x <= 5) dirs[posi] = x - 2;
else{
int pos5 = pos3 + arr1[x - 6];
int pos6 = pos4 + arr2[x - 6];
//cout << posi << " " << pos5 << " " << pos6 << "\n";
if(pos6 > 0) dirs[posi] = 0;
else if(pos6 < 0) dirs[posi] = 1;
else if(pos5 > 0) dirs[posi] = 2;
else if(pos5 < 0) dirs[posi] = 3;
else dirs[posi] = 4;
}
}
}
return dirs;
}
Compilation message
Anna.cpp:17:21: warning: overflow in conversion from 'double' to 'int' changes value from '1.0e+18' to '2147483647' [-Woverflow]
17 | const int oo = 1e18 + 7, mod = 1e9 + 7;
| ~~~~~^~~
Anna.cpp: In function 'void Anna(int, int, std::vector<int>, std::vector<int>)':
Anna.cpp:40:11: warning: unused variable 'pos1' [-Wunused-variable]
40 | int pos1 = r[temp], pos2 = c[temp];
| ^~~~
Anna.cpp:40:27: warning: unused variable 'pos2' [-Wunused-variable]
40 | int pos1 = r[temp], pos2 = c[temp];
| ^~~~
Anna.cpp:61:11: warning: unused variable 'pos1' [-Wunused-variable]
61 | int pos1 = r[temp], pos2 = c[temp];
| ^~~~
Anna.cpp:61:27: warning: unused variable 'pos2' [-Wunused-variable]
61 | int pos1 = r[temp], pos2 = c[temp];
| ^~~~
Bruno.cpp:17:21: warning: overflow in conversion from 'double' to 'int' changes value from '1.0e+18' to '2147483647' [-Woverflow]
17 | const int oo = 1e18 + 7, mod = 1e9 + 7;
| ~~~~~^~~
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
10 ms |
400 KB |
Partially correct |
2 |
Partially correct |
11 ms |
400 KB |
Partially correct |
3 |
Partially correct |
8 ms |
488 KB |
Partially correct |
4 |
Partially correct |
15 ms |
400 KB |
Partially correct |
5 |
Partially correct |
13 ms |
400 KB |
Partially correct |
6 |
Partially correct |
15 ms |
400 KB |
Partially correct |
7 |
Partially correct |
17 ms |
400 KB |
Partially correct |
8 |
Partially correct |
16 ms |
480 KB |
Partially correct |
9 |
Partially correct |
15 ms |
400 KB |
Partially correct |
10 |
Partially correct |
13 ms |
400 KB |
Partially correct |
11 |
Partially correct |
15 ms |
400 KB |
Partially correct |
12 |
Partially correct |
17 ms |
400 KB |
Partially correct |
13 |
Partially correct |
13 ms |
400 KB |
Partially correct |
14 |
Partially correct |
16 ms |
400 KB |
Partially correct |
15 |
Partially correct |
14 ms |
400 KB |
Partially correct |
16 |
Partially correct |
13 ms |
400 KB |
Partially correct |
17 |
Partially correct |
15 ms |
400 KB |
Partially correct |
18 |
Partially correct |
13 ms |
408 KB |
Partially correct |
19 |
Partially correct |
16 ms |
400 KB |
Partially correct |
20 |
Partially correct |
15 ms |
400 KB |
Partially correct |
21 |
Partially correct |
18 ms |
400 KB |
Partially correct |
22 |
Partially correct |
16 ms |
456 KB |
Partially correct |
23 |
Partially correct |
17 ms |
488 KB |
Partially correct |
24 |
Partially correct |
17 ms |
408 KB |
Partially correct |
25 |
Partially correct |
11 ms |
400 KB |
Partially correct |
26 |
Partially correct |
12 ms |
400 KB |
Partially correct |
27 |
Partially correct |
12 ms |
420 KB |
Partially correct |
28 |
Partially correct |
13 ms |
400 KB |
Partially correct |
29 |
Partially correct |
18 ms |
400 KB |
Partially correct |
30 |
Partially correct |
14 ms |
400 KB |
Partially correct |
31 |
Partially correct |
14 ms |
400 KB |
Partially correct |
32 |
Partially correct |
14 ms |
400 KB |
Partially correct |
33 |
Partially correct |
12 ms |
400 KB |
Partially correct |
34 |
Partially correct |
13 ms |
400 KB |
Partially correct |
35 |
Partially correct |
15 ms |
400 KB |
Partially correct |
36 |
Partially correct |
13 ms |
492 KB |
Partially correct |
37 |
Partially correct |
13 ms |
400 KB |
Partially correct |
38 |
Partially correct |
14 ms |
400 KB |
Partially correct |
39 |
Partially correct |
12 ms |
400 KB |
Partially correct |
40 |
Partially correct |
11 ms |
528 KB |
Partially correct |
41 |
Partially correct |
18 ms |
400 KB |
Partially correct |
42 |
Partially correct |
15 ms |
456 KB |
Partially correct |
43 |
Partially correct |
15 ms |
476 KB |
Partially correct |
44 |
Partially correct |
14 ms |
400 KB |
Partially correct |
45 |
Partially correct |
18 ms |
400 KB |
Partially correct |
46 |
Partially correct |
15 ms |
400 KB |
Partially correct |
47 |
Partially correct |
14 ms |
400 KB |
Partially correct |
48 |
Partially correct |
18 ms |
400 KB |
Partially correct |
49 |
Partially correct |
20 ms |
456 KB |
Partially correct |
50 |
Partially correct |
17 ms |
400 KB |
Partially correct |
51 |
Partially correct |
18 ms |
400 KB |
Partially correct |
52 |
Partially correct |
14 ms |
400 KB |
Partially correct |
53 |
Partially correct |
14 ms |
400 KB |
Partially correct |
54 |
Partially correct |
14 ms |
452 KB |
Partially correct |
55 |
Partially correct |
18 ms |
400 KB |
Partially correct |
56 |
Partially correct |
23 ms |
400 KB |
Partially correct |
57 |
Partially correct |
17 ms |
400 KB |
Partially correct |
58 |
Partially correct |
21 ms |
400 KB |
Partially correct |
59 |
Partially correct |
22 ms |
400 KB |
Partially correct |
60 |
Partially correct |
21 ms |
400 KB |
Partially correct |
61 |
Partially correct |
20 ms |
436 KB |
Partially correct |
62 |
Partially correct |
23 ms |
400 KB |
Partially correct |
63 |
Partially correct |
21 ms |
400 KB |
Partially correct |
64 |
Partially correct |
20 ms |
400 KB |
Partially correct |
65 |
Partially correct |
19 ms |
400 KB |
Partially correct |
66 |
Partially correct |
24 ms |
400 KB |
Partially correct |
67 |
Partially correct |
22 ms |
400 KB |
Partially correct |
68 |
Partially correct |
22 ms |
456 KB |
Partially correct |
69 |
Partially correct |
22 ms |
400 KB |
Partially correct |
70 |
Partially correct |
22 ms |
544 KB |
Partially correct |
71 |
Partially correct |
22 ms |
400 KB |
Partially correct |
72 |
Partially correct |
17 ms |
400 KB |
Partially correct |
73 |
Partially correct |
18 ms |
400 KB |
Partially correct |
74 |
Partially correct |
20 ms |
400 KB |
Partially correct |
75 |
Partially correct |
18 ms |
400 KB |
Partially correct |
76 |
Partially correct |
20 ms |
400 KB |
Partially correct |
77 |
Partially correct |
18 ms |
456 KB |
Partially correct |
78 |
Partially correct |
18 ms |
400 KB |
Partially correct |
79 |
Partially correct |
20 ms |
400 KB |
Partially correct |
80 |
Partially correct |
18 ms |
400 KB |
Partially correct |
81 |
Partially correct |
22 ms |
484 KB |
Partially correct |
82 |
Partially correct |
19 ms |
400 KB |
Partially correct |
83 |
Partially correct |
23 ms |
400 KB |
Partially correct |
84 |
Partially correct |
17 ms |
480 KB |
Partially correct |
85 |
Partially correct |
22 ms |
400 KB |
Partially correct |
86 |
Partially correct |
19 ms |
400 KB |
Partially correct |
87 |
Partially correct |
19 ms |
400 KB |
Partially correct |
88 |
Partially correct |
24 ms |
400 KB |
Partially correct |
89 |
Partially correct |
17 ms |
400 KB |
Partially correct |
90 |
Partially correct |
15 ms |
400 KB |
Partially correct |
91 |
Partially correct |
20 ms |
400 KB |
Partially correct |
92 |
Partially correct |
25 ms |
400 KB |
Partially correct |
93 |
Partially correct |
16 ms |
400 KB |
Partially correct |
94 |
Partially correct |
13 ms |
400 KB |
Partially correct |
95 |
Partially correct |
19 ms |
400 KB |
Partially correct |
96 |
Partially correct |
16 ms |
456 KB |
Partially correct |
97 |
Partially correct |
24 ms |
400 KB |
Partially correct |
98 |
Partially correct |
20 ms |
404 KB |
Partially correct |
99 |
Partially correct |
24 ms |
400 KB |
Partially correct |
100 |
Partially correct |
20 ms |
400 KB |
Partially correct |
101 |
Partially correct |
20 ms |
400 KB |
Partially correct |
102 |
Partially correct |
19 ms |
400 KB |
Partially correct |
103 |
Partially correct |
22 ms |
400 KB |
Partially correct |
104 |
Partially correct |
16 ms |
400 KB |
Partially correct |
105 |
Partially correct |
20 ms |
400 KB |
Partially correct |
106 |
Partially correct |
16 ms |
400 KB |
Partially correct |
107 |
Partially correct |
20 ms |
400 KB |
Partially correct |
108 |
Partially correct |
13 ms |
400 KB |
Partially correct |
109 |
Partially correct |
17 ms |
400 KB |
Partially correct |
110 |
Partially correct |
19 ms |
528 KB |
Partially correct |
111 |
Partially correct |
13 ms |
400 KB |
Partially correct |
112 |
Partially correct |
14 ms |
400 KB |
Partially correct |
113 |
Partially correct |
19 ms |
484 KB |
Partially correct |
114 |
Partially correct |
18 ms |
400 KB |
Partially correct |
115 |
Partially correct |
24 ms |
400 KB |
Partially correct |
116 |
Partially correct |
23 ms |
400 KB |
Partially correct |
117 |
Partially correct |
21 ms |
400 KB |
Partially correct |
118 |
Partially correct |
17 ms |
400 KB |
Partially correct |
119 |
Partially correct |
16 ms |
484 KB |
Partially correct |
120 |
Partially correct |
791 ms |
704 KB |
Partially correct |
121 |
Partially correct |
741 ms |
768 KB |
Partially correct |
122 |
Partially correct |
726 ms |
852 KB |
Partially correct |
123 |
Partially correct |
754 ms |
720 KB |
Partially correct |
124 |
Partially correct |
771 ms |
652 KB |
Partially correct |
125 |
Partially correct |
731 ms |
692 KB |
Partially correct |
126 |
Partially correct |
753 ms |
660 KB |
Partially correct |
127 |
Partially correct |
731 ms |
796 KB |
Partially correct |
128 |
Partially correct |
705 ms |
732 KB |
Partially correct |
129 |
Partially correct |
703 ms |
632 KB |
Partially correct |
130 |
Partially correct |
796 ms |
800 KB |
Partially correct |
131 |
Partially correct |
708 ms |
684 KB |
Partially correct |
132 |
Partially correct |
744 ms |
728 KB |
Partially correct |
133 |
Partially correct |
748 ms |
632 KB |
Partially correct |
134 |
Partially correct |
799 ms |
688 KB |
Partially correct |
135 |
Partially correct |
761 ms |
720 KB |
Partially correct |
136 |
Partially correct |
752 ms |
728 KB |
Partially correct |
137 |
Partially correct |
725 ms |
720 KB |
Partially correct |
138 |
Partially correct |
688 ms |
608 KB |
Partially correct |
139 |
Partially correct |
727 ms |
768 KB |
Partially correct |
140 |
Partially correct |
740 ms |
860 KB |
Partially correct |
141 |
Partially correct |
688 ms |
804 KB |
Partially correct |
142 |
Partially correct |
710 ms |
808 KB |
Partially correct |
143 |
Partially correct |
707 ms |
752 KB |
Partially correct |
144 |
Partially correct |
756 ms |
712 KB |
Partially correct |
145 |
Partially correct |
647 ms |
776 KB |
Partially correct |
146 |
Partially correct |
731 ms |
780 KB |
Partially correct |
147 |
Partially correct |
728 ms |
796 KB |
Partially correct |
148 |
Partially correct |
732 ms |
584 KB |
Partially correct |
149 |
Partially correct |
722 ms |
680 KB |
Partially correct |
150 |
Partially correct |
708 ms |
712 KB |
Partially correct |
151 |
Partially correct |
654 ms |
600 KB |
Partially correct |
152 |
Partially correct |
763 ms |
732 KB |
Partially correct |
153 |
Partially correct |
701 ms |
672 KB |
Partially correct |
154 |
Partially correct |
685 ms |
664 KB |
Partially correct |
155 |
Partially correct |
686 ms |
888 KB |
Partially correct |
156 |
Partially correct |
721 ms |
640 KB |
Partially correct |
157 |
Partially correct |
718 ms |
716 KB |
Partially correct |
158 |
Partially correct |
675 ms |
756 KB |
Partially correct |
159 |
Partially correct |
691 ms |
752 KB |
Partially correct |
160 |
Partially correct |
682 ms |
852 KB |
Partially correct |
161 |
Partially correct |
752 ms |
684 KB |
Partially correct |
162 |
Partially correct |
674 ms |
808 KB |
Partially correct |
163 |
Partially correct |
654 ms |
784 KB |
Partially correct |
164 |
Partially correct |
685 ms |
740 KB |
Partially correct |
165 |
Partially correct |
726 ms |
624 KB |
Partially correct |
166 |
Partially correct |
676 ms |
752 KB |
Partially correct |
167 |
Partially correct |
748 ms |
660 KB |
Partially correct |
168 |
Partially correct |
749 ms |
728 KB |
Partially correct |
169 |
Partially correct |
681 ms |
684 KB |
Partially correct |
170 |
Partially correct |
673 ms |
796 KB |
Partially correct |
171 |
Partially correct |
714 ms |
632 KB |
Partially correct |
172 |
Partially correct |
694 ms |
864 KB |
Partially correct |
173 |
Partially correct |
743 ms |
692 KB |
Partially correct |
174 |
Partially correct |
728 ms |
684 KB |
Partially correct |
175 |
Partially correct |
765 ms |
640 KB |
Partially correct |
176 |
Partially correct |
741 ms |
808 KB |
Partially correct |
177 |
Partially correct |
703 ms |
712 KB |
Partially correct |
178 |
Partially correct |
724 ms |
820 KB |
Partially correct |
179 |
Partially correct |
651 ms |
616 KB |
Partially correct |
180 |
Partially correct |
698 ms |
748 KB |
Partially correct |
181 |
Partially correct |
675 ms |
800 KB |
Partially correct |
182 |
Partially correct |
700 ms |
716 KB |
Partially correct |
183 |
Partially correct |
674 ms |
712 KB |
Partially correct |
184 |
Partially correct |
690 ms |
868 KB |
Partially correct |
185 |
Partially correct |
666 ms |
724 KB |
Partially correct |
186 |
Partially correct |
688 ms |
672 KB |
Partially correct |
187 |
Partially correct |
687 ms |
672 KB |
Partially correct |
188 |
Partially correct |
689 ms |
672 KB |
Partially correct |
189 |
Partially correct |
699 ms |
736 KB |
Partially correct |
190 |
Partially correct |
715 ms |
640 KB |
Partially correct |
191 |
Partially correct |
692 ms |
700 KB |
Partially correct |
192 |
Partially correct |
663 ms |
676 KB |
Partially correct |
193 |
Partially correct |
691 ms |
672 KB |
Partially correct |
194 |
Partially correct |
691 ms |
788 KB |
Partially correct |
195 |
Partially correct |
686 ms |
696 KB |
Partially correct |
196 |
Partially correct |
704 ms |
656 KB |
Partially correct |
197 |
Partially correct |
699 ms |
840 KB |
Partially correct |
198 |
Partially correct |
725 ms |
728 KB |
Partially correct |
199 |
Partially correct |
694 ms |
628 KB |
Partially correct |
200 |
Partially correct |
696 ms |
828 KB |
Partially correct |
201 |
Partially correct |
688 ms |
616 KB |
Partially correct |
202 |
Partially correct |
687 ms |
776 KB |
Partially correct |
203 |
Partially correct |
643 ms |
612 KB |
Partially correct |
204 |
Partially correct |
715 ms |
664 KB |
Partially correct |
205 |
Partially correct |
665 ms |
608 KB |
Partially correct |
206 |
Partially correct |
721 ms |
732 KB |
Partially correct |
207 |
Partially correct |
668 ms |
676 KB |
Partially correct |
208 |
Partially correct |
667 ms |
804 KB |
Partially correct |
209 |
Partially correct |
715 ms |
592 KB |
Partially correct |
210 |
Partially correct |
510 ms |
752 KB |
Partially correct |
211 |
Partially correct |
506 ms |
740 KB |
Partially correct |
212 |
Partially correct |
563 ms |
680 KB |
Partially correct |
213 |
Partially correct |
537 ms |
704 KB |
Partially correct |
214 |
Partially correct |
544 ms |
796 KB |
Partially correct |
215 |
Partially correct |
517 ms |
616 KB |
Partially correct |
216 |
Partially correct |
567 ms |
660 KB |
Partially correct |
217 |
Partially correct |
560 ms |
760 KB |
Partially correct |
218 |
Partially correct |
573 ms |
672 KB |
Partially correct |
219 |
Partially correct |
565 ms |
664 KB |
Partially correct |
220 |
Partially correct |
576 ms |
792 KB |
Partially correct |
221 |
Partially correct |
498 ms |
696 KB |
Partially correct |
222 |
Partially correct |
582 ms |
704 KB |
Partially correct |
223 |
Partially correct |
546 ms |
808 KB |
Partially correct |
224 |
Partially correct |
533 ms |
656 KB |
Partially correct |
225 |
Partially correct |
525 ms |
656 KB |
Partially correct |
226 |
Partially correct |
530 ms |
704 KB |
Partially correct |