#include <bits/stdc++.h>
#include "Anna.h"
using namespace std;
//~ 1: move right
//~ 2: move left
//~ 3: move down
//~ 4: move up
//~ 5: (x - 1, y - 1)
//~ 6: (x - 1, y)
//~ 7: (x - 1, y + 1)
//~ 8: (x, y - 1)
//~ 9: (x, y)
//~ 10: (x, y + 1)
//~ 11: (x + 1, y - 1)
//~ 12: (x + 1, y)
//~ 13: (x + 1, y + 1)
int calc(pair <int, int> l, pair <int, int> r){
if(abs(l.first - r.first) > 1){
if(r.first < l.first) return 4;
else return 3;
}
else if(abs(l.second - r.second) > 1){
if(r.second < l.second) return 2;
else return 1;
}
else if(l.first - 1 == r.first){
if(l.second - 1 == r.second) return 5;
else if(l.second == r.second) return 6;
else return 7;
}
else if(l.first == r.first){
if(l.second - 1 == r.second) return 8;
else if(l.second == r.second) return 9;
else return 10;
}
else{
if(l.second - 1 == r.second) return 11;
else if(l.second == r.second) return 12;
else return 13;
}
}
void Anna(int N, int K, std::vector<int> R, std::vector<int> C) {
for(int i = 0 ; i < N ; i++){
vector <int> cur;
if(i % 3 == 0) cur = {0, 1, 2};
else if(i % 3 == 1) cur = {3, 4, 5};
else cur = {6, 7, 8};
for(int j = 0 ; j < N ; j++){
int idx = cur[j % cur.size()];
if(idx == 7){
SetFlag(i, j, 14);
}
else if(idx == 8){
SetFlag(i, j, 14);
}
else{
SetFlag(i, j, calc(make_pair(i, j), make_pair(R[idx], C[idx])));
}
}
}
}
#include <bits/stdc++.h>
#include "Bruno.h"
using namespace std;
std::vector<int> Bruno(int K, std::vector<int> value) {
vector <vector <int> > v(3, vector <int>(3));
for(int k = 0 ; k < 9 ; k++){
v[k / 3][k % 3] = value[k];
}
vector <pair <int, int> > f;
for(int i = 0 ; i < 3 ; i++){
for(int j = 0 ; j < 3 ; j++){
if(v[i][j] == 14){
f.push_back(make_pair(i, j));
}
}
}
assert(f.size() == 2);
int rmod, cmod;
rmod = 2 - f[0].first;
if(f[0].second == 1 && f[1].second == 2) cmod = 0;
else if(f[0].second == 0 && f[1].second == 1) cmod = 1;
else cmod = 2;
vector <int> ret(7);
for(int i = 0 ; i < 3 ; i++){
vector <int> cur;
if((rmod + i) % 3 == 0) cur = {0, 1, 2};
else if((rmod + i) % 3 == 1) cur = {3, 4, 5};
else cur = {6, 7, 8};
for(int j = 0 ; j < 3 ; j++){
int idx = cur[(cmod + j) % cur.size()];
if(idx > 6) continue;
if(v[i][j] <= 4) ret[idx] = v[i][j] - 1;
else{
pair <int, int> p = make_pair(i, j);
if(v[i][j] == 5) p.first--, p.second--;
else if(v[i][j] == 6) p.first--;
else if(v[i][j] == 7) p.first--, p.second++;
else if(v[i][j] == 8) p.second--;
else if(v[i][j] == 10) p.second++;
else if(v[i][j] == 11) p.first++, p.second--;
else if(v[i][j] == 12) p.first++;
else if(v[i][j] == 13) p.first++, p.second++;
if(p.first < 1) ret[idx] = 3;
else if(p.first > 1) ret[idx] = 2;
else if(p.second < 1) ret[idx] = 1;
else if(p.second > 1) ret[idx] = 0;
else ret[idx] = 4;
}
}
}
return ret;
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Partially correct |
15 ms |
384 KB |
Partially correct |
2 |
Partially correct |
15 ms |
384 KB |
Partially correct |
3 |
Partially correct |
13 ms |
384 KB |
Partially correct |
4 |
Partially correct |
14 ms |
384 KB |
Partially correct |
5 |
Partially correct |
15 ms |
384 KB |
Partially correct |
6 |
Partially correct |
20 ms |
384 KB |
Partially correct |
7 |
Partially correct |
19 ms |
456 KB |
Partially correct |
8 |
Partially correct |
14 ms |
384 KB |
Partially correct |
9 |
Partially correct |
14 ms |
384 KB |
Partially correct |
10 |
Partially correct |
14 ms |
384 KB |
Partially correct |
11 |
Partially correct |
17 ms |
384 KB |
Partially correct |
12 |
Partially correct |
17 ms |
384 KB |
Partially correct |
13 |
Partially correct |
18 ms |
384 KB |
Partially correct |
14 |
Partially correct |
14 ms |
384 KB |
Partially correct |
15 |
Partially correct |
15 ms |
468 KB |
Partially correct |
16 |
Partially correct |
17 ms |
384 KB |
Partially correct |
17 |
Partially correct |
20 ms |
384 KB |
Partially correct |
18 |
Partially correct |
18 ms |
384 KB |
Partially correct |
19 |
Partially correct |
14 ms |
388 KB |
Partially correct |
20 |
Partially correct |
14 ms |
384 KB |
Partially correct |
21 |
Partially correct |
16 ms |
384 KB |
Partially correct |
22 |
Partially correct |
15 ms |
384 KB |
Partially correct |
23 |
Partially correct |
13 ms |
384 KB |
Partially correct |
24 |
Partially correct |
16 ms |
384 KB |
Partially correct |
25 |
Partially correct |
11 ms |
468 KB |
Partially correct |
26 |
Partially correct |
18 ms |
468 KB |
Partially correct |
27 |
Partially correct |
16 ms |
404 KB |
Partially correct |
28 |
Partially correct |
14 ms |
384 KB |
Partially correct |
29 |
Partially correct |
13 ms |
468 KB |
Partially correct |
30 |
Partially correct |
13 ms |
388 KB |
Partially correct |
31 |
Partially correct |
14 ms |
388 KB |
Partially correct |
32 |
Partially correct |
15 ms |
384 KB |
Partially correct |
33 |
Partially correct |
17 ms |
388 KB |
Partially correct |
34 |
Partially correct |
17 ms |
392 KB |
Partially correct |
35 |
Partially correct |
14 ms |
384 KB |
Partially correct |
36 |
Partially correct |
14 ms |
388 KB |
Partially correct |
37 |
Partially correct |
16 ms |
384 KB |
Partially correct |
38 |
Partially correct |
16 ms |
388 KB |
Partially correct |
39 |
Partially correct |
17 ms |
388 KB |
Partially correct |
40 |
Partially correct |
20 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 |
11 ms |
384 KB |
Partially correct |
44 |
Partially correct |
13 ms |
384 KB |
Partially correct |
45 |
Partially correct |
18 ms |
384 KB |
Partially correct |
46 |
Partially correct |
23 ms |
384 KB |
Partially correct |
47 |
Partially correct |
18 ms |
392 KB |
Partially correct |
48 |
Partially correct |
18 ms |
468 KB |
Partially correct |
49 |
Partially correct |
19 ms |
384 KB |
Partially correct |
50 |
Partially correct |
20 ms |
384 KB |
Partially correct |
51 |
Partially correct |
18 ms |
384 KB |
Partially correct |
52 |
Partially correct |
17 ms |
384 KB |
Partially correct |
53 |
Partially correct |
14 ms |
468 KB |
Partially correct |
54 |
Partially correct |
15 ms |
468 KB |
Partially correct |
55 |
Partially correct |
18 ms |
384 KB |
Partially correct |
56 |
Partially correct |
22 ms |
392 KB |
Partially correct |
57 |
Partially correct |
17 ms |
472 KB |
Partially correct |
58 |
Partially correct |
20 ms |
388 KB |
Partially correct |
59 |
Partially correct |
20 ms |
388 KB |
Partially correct |
60 |
Partially correct |
15 ms |
468 KB |
Partially correct |
61 |
Partially correct |
25 ms |
384 KB |
Partially correct |
62 |
Partially correct |
20 ms |
388 KB |
Partially correct |
63 |
Partially correct |
20 ms |
384 KB |
Partially correct |
64 |
Partially correct |
19 ms |
464 KB |
Partially correct |
65 |
Partially correct |
20 ms |
384 KB |
Partially correct |
66 |
Partially correct |
20 ms |
384 KB |
Partially correct |
67 |
Partially correct |
25 ms |
384 KB |
Partially correct |
68 |
Partially correct |
17 ms |
384 KB |
Partially correct |
69 |
Partially correct |
20 ms |
384 KB |
Partially correct |
70 |
Partially correct |
19 ms |
384 KB |
Partially correct |
71 |
Partially correct |
19 ms |
384 KB |
Partially correct |
72 |
Partially correct |
18 ms |
384 KB |
Partially correct |
73 |
Partially correct |
26 ms |
384 KB |
Partially correct |
74 |
Partially correct |
18 ms |
388 KB |
Partially correct |
75 |
Partially correct |
22 ms |
384 KB |
Partially correct |
76 |
Partially correct |
20 ms |
384 KB |
Partially correct |
77 |
Partially correct |
16 ms |
388 KB |
Partially correct |
78 |
Partially correct |
20 ms |
384 KB |
Partially correct |
79 |
Partially correct |
18 ms |
384 KB |
Partially correct |
80 |
Partially correct |
18 ms |
384 KB |
Partially correct |
81 |
Partially correct |
27 ms |
384 KB |
Partially correct |
82 |
Partially correct |
20 ms |
384 KB |
Partially correct |
83 |
Partially correct |
20 ms |
384 KB |
Partially correct |
84 |
Partially correct |
26 ms |
384 KB |
Partially correct |
85 |
Partially correct |
24 ms |
384 KB |
Partially correct |
86 |
Partially correct |
19 ms |
460 KB |
Partially correct |
87 |
Partially correct |
23 ms |
384 KB |
Partially correct |
88 |
Partially correct |
26 ms |
384 KB |
Partially correct |
89 |
Partially correct |
20 ms |
384 KB |
Partially correct |
90 |
Partially correct |
19 ms |
384 KB |
Partially correct |
91 |
Partially correct |
20 ms |
384 KB |
Partially correct |
92 |
Partially correct |
20 ms |
384 KB |
Partially correct |
93 |
Partially correct |
19 ms |
472 KB |
Partially correct |
94 |
Partially correct |
18 ms |
384 KB |
Partially correct |
95 |
Partially correct |
18 ms |
384 KB |
Partially correct |
96 |
Partially correct |
20 ms |
384 KB |
Partially correct |
97 |
Partially correct |
18 ms |
384 KB |
Partially correct |
98 |
Partially correct |
18 ms |
384 KB |
Partially correct |
99 |
Partially correct |
20 ms |
384 KB |
Partially correct |
100 |
Partially correct |
23 ms |
384 KB |
Partially correct |
101 |
Partially correct |
20 ms |
384 KB |
Partially correct |
102 |
Partially correct |
18 ms |
468 KB |
Partially correct |
103 |
Partially correct |
17 ms |
384 KB |
Partially correct |
104 |
Partially correct |
23 ms |
384 KB |
Partially correct |
105 |
Partially correct |
27 ms |
384 KB |
Partially correct |
106 |
Partially correct |
17 ms |
472 KB |
Partially correct |
107 |
Partially correct |
23 ms |
384 KB |
Partially correct |
108 |
Partially correct |
20 ms |
384 KB |
Partially correct |
109 |
Partially correct |
18 ms |
384 KB |
Partially correct |
110 |
Partially correct |
16 ms |
384 KB |
Partially correct |
111 |
Partially correct |
20 ms |
384 KB |
Partially correct |
112 |
Partially correct |
20 ms |
384 KB |
Partially correct |
113 |
Partially correct |
22 ms |
384 KB |
Partially correct |
114 |
Partially correct |
20 ms |
384 KB |
Partially correct |
115 |
Partially correct |
20 ms |
384 KB |
Partially correct |
116 |
Partially correct |
18 ms |
384 KB |
Partially correct |
117 |
Partially correct |
19 ms |
384 KB |
Partially correct |
118 |
Partially correct |
18 ms |
384 KB |
Partially correct |
119 |
Partially correct |
18 ms |
384 KB |
Partially correct |
120 |
Partially correct |
701 ms |
540 KB |
Partially correct |
121 |
Partially correct |
697 ms |
672 KB |
Partially correct |
122 |
Partially correct |
705 ms |
676 KB |
Partially correct |
123 |
Partially correct |
729 ms |
600 KB |
Partially correct |
124 |
Partially correct |
777 ms |
604 KB |
Partially correct |
125 |
Partially correct |
708 ms |
620 KB |
Partially correct |
126 |
Partially correct |
754 ms |
820 KB |
Partially correct |
127 |
Partially correct |
694 ms |
736 KB |
Partially correct |
128 |
Partially correct |
697 ms |
696 KB |
Partially correct |
129 |
Partially correct |
809 ms |
516 KB |
Partially correct |
130 |
Partially correct |
694 ms |
568 KB |
Partially correct |
131 |
Partially correct |
712 ms |
656 KB |
Partially correct |
132 |
Partially correct |
692 ms |
692 KB |
Partially correct |
133 |
Partially correct |
697 ms |
600 KB |
Partially correct |
134 |
Partially correct |
762 ms |
512 KB |
Partially correct |
135 |
Partially correct |
768 ms |
852 KB |
Partially correct |
136 |
Partially correct |
716 ms |
664 KB |
Partially correct |
137 |
Partially correct |
757 ms |
636 KB |
Partially correct |
138 |
Partially correct |
695 ms |
696 KB |
Partially correct |
139 |
Partially correct |
843 ms |
572 KB |
Partially correct |
140 |
Partially correct |
693 ms |
716 KB |
Partially correct |
141 |
Partially correct |
757 ms |
760 KB |
Partially correct |
142 |
Partially correct |
694 ms |
584 KB |
Partially correct |
143 |
Partially correct |
762 ms |
488 KB |
Partially correct |
144 |
Partially correct |
702 ms |
484 KB |
Partially correct |
145 |
Partially correct |
731 ms |
620 KB |
Partially correct |
146 |
Partially correct |
822 ms |
672 KB |
Partially correct |
147 |
Partially correct |
729 ms |
800 KB |
Partially correct |
148 |
Partially correct |
748 ms |
556 KB |
Partially correct |
149 |
Partially correct |
805 ms |
724 KB |
Partially correct |
150 |
Partially correct |
715 ms |
580 KB |
Partially correct |
151 |
Partially correct |
703 ms |
616 KB |
Partially correct |
152 |
Partially correct |
762 ms |
612 KB |
Partially correct |
153 |
Partially correct |
689 ms |
572 KB |
Partially correct |
154 |
Partially correct |
692 ms |
716 KB |
Partially correct |
155 |
Partially correct |
718 ms |
768 KB |
Partially correct |
156 |
Partially correct |
698 ms |
608 KB |
Partially correct |
157 |
Partially correct |
751 ms |
500 KB |
Partially correct |
158 |
Partially correct |
842 ms |
808 KB |
Partially correct |
159 |
Partially correct |
739 ms |
504 KB |
Partially correct |
160 |
Partially correct |
710 ms |
604 KB |
Partially correct |
161 |
Partially correct |
706 ms |
556 KB |
Partially correct |
162 |
Partially correct |
696 ms |
688 KB |
Partially correct |
163 |
Partially correct |
738 ms |
708 KB |
Partially correct |
164 |
Partially correct |
693 ms |
652 KB |
Partially correct |
165 |
Partially correct |
705 ms |
608 KB |
Partially correct |
166 |
Partially correct |
699 ms |
884 KB |
Partially correct |
167 |
Partially correct |
693 ms |
800 KB |
Partially correct |
168 |
Partially correct |
693 ms |
664 KB |
Partially correct |
169 |
Partially correct |
745 ms |
664 KB |
Partially correct |
170 |
Partially correct |
697 ms |
512 KB |
Partially correct |
171 |
Partially correct |
711 ms |
564 KB |
Partially correct |
172 |
Partially correct |
717 ms |
636 KB |
Partially correct |
173 |
Partially correct |
767 ms |
528 KB |
Partially correct |
174 |
Partially correct |
717 ms |
540 KB |
Partially correct |
175 |
Partially correct |
823 ms |
676 KB |
Partially correct |
176 |
Partially correct |
713 ms |
644 KB |
Partially correct |
177 |
Partially correct |
725 ms |
592 KB |
Partially correct |
178 |
Partially correct |
750 ms |
508 KB |
Partially correct |
179 |
Partially correct |
812 ms |
604 KB |
Partially correct |
180 |
Partially correct |
740 ms |
668 KB |
Partially correct |
181 |
Partially correct |
724 ms |
652 KB |
Partially correct |
182 |
Partially correct |
712 ms |
644 KB |
Partially correct |
183 |
Partially correct |
695 ms |
652 KB |
Partially correct |
184 |
Partially correct |
788 ms |
608 KB |
Partially correct |
185 |
Partially correct |
796 ms |
656 KB |
Partially correct |
186 |
Partially correct |
732 ms |
784 KB |
Partially correct |
187 |
Partially correct |
698 ms |
612 KB |
Partially correct |
188 |
Partially correct |
733 ms |
708 KB |
Partially correct |
189 |
Partially correct |
702 ms |
772 KB |
Partially correct |
190 |
Partially correct |
764 ms |
564 KB |
Partially correct |
191 |
Partially correct |
724 ms |
712 KB |
Partially correct |
192 |
Partially correct |
696 ms |
636 KB |
Partially correct |
193 |
Partially correct |
752 ms |
696 KB |
Partially correct |
194 |
Partially correct |
785 ms |
612 KB |
Partially correct |
195 |
Partially correct |
729 ms |
760 KB |
Partially correct |
196 |
Partially correct |
688 ms |
708 KB |
Partially correct |
197 |
Partially correct |
702 ms |
652 KB |
Partially correct |
198 |
Partially correct |
731 ms |
596 KB |
Partially correct |
199 |
Partially correct |
755 ms |
612 KB |
Partially correct |
200 |
Partially correct |
728 ms |
696 KB |
Partially correct |
201 |
Partially correct |
707 ms |
672 KB |
Partially correct |
202 |
Partially correct |
690 ms |
588 KB |
Partially correct |
203 |
Partially correct |
881 ms |
748 KB |
Partially correct |
204 |
Partially correct |
752 ms |
692 KB |
Partially correct |
205 |
Partially correct |
704 ms |
492 KB |
Partially correct |
206 |
Partially correct |
777 ms |
556 KB |
Partially correct |
207 |
Partially correct |
785 ms |
668 KB |
Partially correct |
208 |
Partially correct |
707 ms |
732 KB |
Partially correct |
209 |
Partially correct |
680 ms |
676 KB |
Partially correct |
210 |
Partially correct |
625 ms |
504 KB |
Partially correct |
211 |
Partially correct |
514 ms |
640 KB |
Partially correct |
212 |
Partially correct |
571 ms |
696 KB |
Partially correct |
213 |
Partially correct |
581 ms |
564 KB |
Partially correct |
214 |
Partially correct |
556 ms |
816 KB |
Partially correct |
215 |
Partially correct |
523 ms |
692 KB |
Partially correct |
216 |
Partially correct |
561 ms |
668 KB |
Partially correct |
217 |
Partially correct |
522 ms |
600 KB |
Partially correct |
218 |
Partially correct |
562 ms |
628 KB |
Partially correct |
219 |
Partially correct |
549 ms |
592 KB |
Partially correct |
220 |
Partially correct |
520 ms |
568 KB |
Partially correct |
221 |
Partially correct |
533 ms |
660 KB |
Partially correct |
222 |
Partially correct |
520 ms |
560 KB |
Partially correct |
223 |
Partially correct |
564 ms |
580 KB |
Partially correct |
224 |
Partially correct |
540 ms |
564 KB |
Partially correct |
225 |
Partially correct |
533 ms |
564 KB |
Partially correct |
226 |
Partially correct |
555 ms |
648 KB |
Partially correct |