QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#447767 | #7999. 拉丁方 | james1BadCreeper | 100 ✓ | 3707ms | 10644kb | C++17 | 2.4kb | 2024-06-18 19:44:31 | 2024-06-18 19:44:31 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
int n, R, C;
int a[505][505];
const int M = 505 * 505;
struct Solver {
int u[M], v[M], deg[M], col[M];
int e[1005][505], m, ans;
void init(void) {
ans = 0;
m = 0; memset(deg, 0, sizeof deg); memset(col, 0, sizeof col); memset(e, 0, sizeof e);
}
inline void addedge(int x, int y) {
++m; y += n;
u[m] = x; v[m] = y; ++deg[x]; ++deg[y];
ans = max(ans, deg[x]);
ans = max(ans, deg[y]);
}
void solve(void) {
for (int i = 1; i <= m; ++i) {
int c1 = 1, c2 = 1;
while (e[u[i]][c1]) ++c1;
while (e[v[i]][c2]) ++c2;
e[u[i]][c1] = v[i]; e[v[i]][c2] = u[i];
if (c1 == c2) continue;
// u[i] -> v[i] 强制染色 c1
for (int tmp = c2, w = v[i]; w; w = e[w][tmp], tmp = tmp == c1 ? c2 : c1)
swap(e[w][c1], e[w][c2]);
}
}
} S;
void solve(void) {
memset(a, 0, sizeof a);
cin >> n >> R >> C;
for (int i = 1; i <= R; ++i) for (int j = 1; j <= C; ++j) cin >> a[i][j];
S.init();
for (int i = 1; i <= n; ++i)
for (int j = 1; j <= R; ++j) {
bool flg = 1;
for (int k = 1; k <= C; ++k)
if (a[j][k] == i) { flg = 0; break; }
if (flg) S.addedge(i, j); // , cerr << i << " " << j << "\n";
}
// cerr << S.ans << "\n";
if (S.ans > n - C) return cout << "No\n", void();
S.solve();
for (int i = 1; i <= S.m; ++i)
for (int j = 1; j <= S.ans; ++j)
if (S.e[S.u[i]][j] == S.v[i]) a[S.v[i] - n][j + C] = S.u[i];
S.init();
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= n; ++j) {
bool flg = 1;
for (int k = 1; k <= R; ++k)
if (a[k][j] == i) { flg = 0; break; }
if (flg) S.addedge(i, j);
}
}
S.solve();
for (int i = 1; i <= S.m; ++i)
for (int j = 1; j <= S.ans; ++j)
if (S.e[S.u[i]][j] == S.v[i]) a[j + R][S.v[i] - n] = S.u[i];
cout << "Yes\n";
for (int i = 1; i <= n; ++i) for (int j = 1; j <= n; ++j)
cout << a[i][j] << " \n"[j == n];
}
int main(void) {
ios::sync_with_stdio(0);
int T = 1; cin >> T;
while (T--) solve();
return 0;
}
詳細信息
Test #1:
score: 5
Accepted
time: 0ms
memory: 8532kb
input:
10 6 2 1 1 3 6 2 4 1 4 2 6 6 5 4 3 6 4 4 4 1 5 3 5 2 1 6 6 3 2 4 2 6 3 5 6 6 3 4 5 1 1 2 4 3 6 2 2 4 6 6 3 5 5 1 3 6 1 2 4 3 6 2 2 5 2 3 1 6 2 1 5 3 6 4 6 1 6 2 4 3 5 4 2 3 5 1 6 3 5 1 6 4 2 6 3 4 2 5 1 6 1 4 2 6 1 5 6 3 4 3 1 2 4 4 3 5 2 2 5 4 1
output:
Yes 1 6 5 3 2 4 3 2 6 1 4 5 6 5 4 2 1 3 5 4 2 6 3 1 4 3 1 5 6 2 2 1 3 4 5 6 Yes 1 4 2 6 5 3 6 5 4 3 2 1 5 6 3 4 1 2 3 1 6 2 4 5 2 3 1 5 6 4 4 2 5 1 3 6 Yes 4 1 5 3 6 2 5 2 1 6 4 3 6 3 2 4 5 1 2 6 3 5 1 4 3 4 6 1 2 5 1 5 4 2 3 6 Yes 4 5 1 6 3 2 1 2 4 5 6 3 3 6 2 4 5 1 2 4 6 3 1 5 6 3 5 1 2 4 5 1 3 2 ...
result:
ok ok (10 test cases)
Test #2:
score: 5
Accepted
time: 3ms
memory: 8576kb
input:
10 6 2 1 5 4 6 4 1 3 1 2 6 6 1 4 6 4 2 3 6 4 2 2 5 4 1 6 3 3 2 6 2 4 4 6 2 3 2 5 4 1 6 2 2 3 5 1 2 6 3 2 6 2 5 3 1 4 6 3 2 5 3 1 4 6 2 6 5 2 5 1 2 6 3 4 1 2 6 5 6 3 4 5 1 4 2 4 5 3 1 3 2 1 5
output:
Yes 5 6 2 1 3 4 4 5 6 2 1 3 6 1 5 3 4 2 1 4 3 6 2 5 3 2 4 5 6 1 2 3 1 4 5 6 Yes 3 6 5 4 2 1 1 2 6 5 3 4 2 1 3 6 4 5 6 4 2 1 5 3 4 5 1 3 6 2 5 3 4 2 1 6 Yes 6 4 2 3 5 1 2 6 3 4 1 5 4 5 6 1 2 3 5 2 1 6 3 4 1 3 4 5 6 2 3 1 5 2 4 6 Yes 2 5 6 1 3 4 4 1 5 6 2 3 6 3 4 5 1 2 3 2 1 4 6 5 5 6 3 2 4 1 1 4 2 3 ...
result:
ok ok (10 test cases)
Test #3:
score: 5
Accepted
time: 0ms
memory: 8584kb
input:
10 10 7 7 1 7 5 10 2 3 4 5 2 4 9 6 8 10 3 10 1 6 4 7 5 4 8 2 7 1 9 3 9 6 3 8 10 5 1 7 4 9 3 5 1 6 6 3 10 1 8 2 9 10 3 9 8 7 2 9 3 6 10 1 5 1 3 7 5 10 9 6 4 2 2 6 8 10 1 4 5 9 7 10 1 7 5 10 3 6 2 8 7 10 3 7 8 1 7 9 3 4 10 5 10 1 8 7 2 3 9 3 2 4 6 10 5 10 1 3 2 7 8 10 1 8 6 4 2 10 5 8 3 1 10 9 9 2 5 4...
output:
Yes 1 7 5 10 2 3 4 6 8 9 5 2 4 9 6 8 10 1 7 3 3 10 1 6 4 7 5 2 9 8 4 8 2 7 1 9 3 10 5 6 9 6 3 8 10 5 1 7 2 4 7 4 9 3 5 1 6 8 10 2 6 3 10 1 8 2 9 5 4 7 10 1 7 2 3 4 8 9 6 5 8 9 6 5 7 10 2 4 3 1 2 5 8 4 9 6 7 3 1 10 Yes 8 7 2 9 3 6 10 1 5 4 1 3 7 5 10 9 6 4 2 8 2 6 8 10 1 4 5 9 7 3 10 5 4 3 7 2 8 6 9 ...
result:
ok ok (10 test cases)
Test #4:
score: 5
Accepted
time: 0ms
memory: 8632kb
input:
10 10 1 1 10 10 8 8 1 7 5 2 3 6 4 10 2 3 4 7 9 8 5 6 9 8 6 10 1 5 2 3 5 10 3 9 4 7 1 8 4 6 1 8 10 2 7 9 7 5 9 4 2 3 8 1 3 2 7 6 5 10 9 4 10 9 8 1 6 4 3 5 10 4 7 10 7 5 3 6 9 4 3 8 7 9 1 4 10 6 5 4 1 10 2 3 2 4 10 8 7 5 6 10 5 2 6 7 4 2 9 5 3 10 8 1 10 4 7 9 6 5 1 4 2 10 7 4 2 8 10 5 3 10 1 3 9 7 8 5...
output:
Yes 10 9 1 2 3 4 5 6 7 8 5 10 9 7 1 6 3 2 8 4 9 2 10 4 7 8 1 3 6 5 4 1 8 10 2 7 6 9 5 3 6 5 4 8 10 2 7 1 3 9 7 4 5 3 6 10 2 8 9 1 8 3 2 6 9 5 10 4 1 7 3 7 6 9 5 1 8 10 4 2 2 8 7 1 4 3 9 5 10 6 1 6 3 5 8 9 4 7 2 10 Yes 1 7 5 2 3 6 4 10 8 9 2 3 4 7 9 8 5 6 10 1 9 8 6 10 1 5 2 3 4 7 5 10 3 9 4 7 1 8 2 ...
result:
ok ok (10 test cases)
Test #5:
score: 5
Accepted
time: 3707ms
memory: 10644kb
input:
10 500 1 39 201 443 328 346 404 472 146 117 171 389 321 403 420 280 197 343 126 315 108 39 42 278 303 11 255 330 101 422 263 281 496 110 97 159 406 241 178 187 179 500 1 362 278 200 441 177 47 404 184 261 199 492 198 470 39 71 297 72 134 157 92 313 269 40 304 168 447 290 224 181 481 218 489 374 383 ...
output:
Yes 201 443 328 346 404 472 146 117 171 389 321 403 420 280 197 343 126 315 108 39 42 278 303 11 255 330 101 422 263 281 496 110 97 159 406 241 178 187 179 500 1 2 3 4 5 6 7 8 9 10 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 40 41 43 44 45 46 47 48 49 50 51 52 53...
result:
ok ok (10 test cases)
Test #6:
score: 5
Accepted
time: 21ms
memory: 8664kb
input:
10 100 59 100 89 11 52 81 39 8 35 20 63 73 96 13 7 78 67 46 6 51 90 27 25 68 5 40 44 70 38 36 19 10 54 3 91 56 1 86 82 15 74 71 66 48 16 75 21 29 55 77 61 95 60 57 30 53 4 9 99 22 65 2 47 17 24 23 59 62 28 97 87 43 79 98 41 33 14 64 45 69 50 93 26 88 34 49 100 84 72 37 80 58 94 92 12 42 76 85 83 18 ...
output:
Yes 89 11 52 81 39 8 35 20 63 73 96 13 7 78 67 46 6 51 90 27 25 68 5 40 44 70 38 36 19 10 54 3 91 56 1 86 82 15 74 71 66 48 16 75 21 29 55 77 61 95 60 57 30 53 4 9 99 22 65 2 47 17 24 23 59 62 28 97 87 43 79 98 41 33 14 64 45 69 50 93 26 88 34 49 100 84 72 37 80 58 94 92 12 42 76 85 83 18 32 31 45 1...
result:
ok ok (10 test cases)
Test #7:
score: 5
Accepted
time: 19ms
memory: 8668kb
input:
10 100 87 100 1 86 29 33 80 26 57 15 60 2 52 93 100 56 32 4 96 34 85 91 43 72 19 83 16 75 39 35 64 31 82 74 36 17 14 25 63 58 54 18 22 13 94 73 98 37 68 30 20 41 10 95 45 42 61 38 78 12 49 55 84 3 53 7 81 40 47 66 92 76 59 6 79 99 89 70 77 23 62 97 28 24 44 67 88 5 46 8 9 87 27 11 65 69 21 51 71 48 ...
output:
Yes 1 86 29 33 80 26 57 15 60 2 52 93 100 56 32 4 96 34 85 91 43 72 19 83 16 75 39 35 64 31 82 74 36 17 14 25 63 58 54 18 22 13 94 73 98 37 68 30 20 41 10 95 45 42 61 38 78 12 49 55 84 3 53 7 81 40 47 66 92 76 59 6 79 99 89 70 77 23 62 97 28 24 44 67 88 5 46 8 9 87 27 11 65 69 21 51 71 48 90 50 63 5...
result:
ok ok (10 test cases)
Test #8:
score: 5
Accepted
time: 272ms
memory: 9260kb
input:
10 300 115 300 258 235 113 48 246 149 278 25 90 216 220 299 69 285 134 206 39 52 15 265 111 28 94 11 194 187 242 154 62 60 116 135 86 144 124 108 119 283 282 211 245 295 112 261 4 2 10 244 267 196 83 143 105 70 40 272 55 155 97 74 13 65 132 288 170 174 260 165 46 151 252 53 32 201 66 142 274 27 30 1...
output:
Yes 258 235 113 48 246 149 278 25 90 216 220 299 69 285 134 206 39 52 15 265 111 28 94 11 194 187 242 154 62 60 116 135 86 144 124 108 119 283 282 211 245 295 112 261 4 2 10 244 267 196 83 143 105 70 40 272 55 155 97 74 13 65 132 288 170 174 260 165 46 151 252 53 32 201 66 142 274 27 30 197 96 98 19...
result:
ok ok (10 test cases)
Test #9:
score: 5
Accepted
time: 292ms
memory: 9252kb
input:
10 300 39 300 153 47 152 270 96 202 24 212 109 69 160 116 133 91 150 258 246 8 295 210 223 99 178 159 32 205 101 23 213 26 89 281 117 218 106 75 215 290 104 82 113 105 174 71 297 242 197 115 221 225 5 122 286 94 9 200 28 203 33 77 108 234 12 279 7 34 154 229 62 143 186 142 275 168 196 111 25 51 156 ...
output:
Yes 153 47 152 270 96 202 24 212 109 69 160 116 133 91 150 258 246 8 295 210 223 99 178 159 32 205 101 23 213 26 89 281 117 218 106 75 215 290 104 82 113 105 174 71 297 242 197 115 221 225 5 122 286 94 9 200 28 203 33 77 108 234 12 279 7 34 154 229 62 143 186 142 275 168 196 111 25 51 156 228 193 4 ...
result:
ok ok (10 test cases)
Test #10:
score: 5
Accepted
time: 1057ms
memory: 10416kb
input:
10 500 18 500 282 102 421 339 20 225 141 221 457 330 196 314 245 377 7 39 113 106 111 57 495 479 480 388 405 367 398 112 101 379 251 255 208 75 4 66 392 284 93 395 86 231 96 125 368 448 149 400 322 427 378 199 97 474 477 100 85 45 258 138 281 273 363 202 288 493 328 483 357 190 194 43 289 19 319 137...
output:
Yes 282 102 421 339 20 225 141 221 457 330 196 314 245 377 7 39 113 106 111 57 495 479 480 388 405 367 398 112 101 379 251 255 208 75 4 66 392 284 93 395 86 231 96 125 368 448 149 400 322 427 378 199 97 474 477 100 85 45 258 138 281 273 363 202 288 493 328 483 357 190 194 43 289 19 319 137 404 209 2...
result:
ok ok (10 test cases)
Test #11:
score: 5
Accepted
time: 1503ms
memory: 10496kb
input:
10 500 171 146 271 474 337 28 15 9 494 482 381 404 25 74 465 378 446 11 150 160 434 199 248 419 221 354 425 265 215 94 426 197 288 287 236 223 259 8 167 453 284 499 483 473 171 62 464 383 2 476 313 116 394 293 212 182 347 457 108 325 95 82 396 96 254 432 90 79 247 351 303 110 54 459 460 311 158 415 ...
output:
Yes 271 474 337 28 15 9 494 482 381 404 25 74 465 378 446 11 150 160 434 199 248 419 221 354 425 265 215 94 426 197 288 287 236 223 259 8 167 453 284 499 483 473 171 62 464 383 2 476 313 116 394 293 212 182 347 457 108 325 95 82 396 96 254 432 90 79 247 351 303 110 54 459 460 311 158 415 469 149 268...
result:
ok ok (10 test cases)
Test #12:
score: 5
Accepted
time: 1510ms
memory: 10492kb
input:
10 500 61 70 15 300 446 146 477 420 244 462 443 49 328 24 158 440 47 18 43 388 258 366 488 312 426 138 359 114 489 130 464 407 190 450 471 391 55 89 345 131 393 247 39 265 196 78 299 384 135 219 179 184 313 406 73 424 193 459 291 343 434 58 427 92 295 441 83 285 87 397 499 493 494 55 314 100 383 7 3...
output:
Yes 15 300 446 146 477 420 244 462 443 49 328 24 158 440 47 18 43 388 258 366 488 312 426 138 359 114 489 130 464 407 190 450 471 391 55 89 345 131 393 247 39 265 196 78 299 384 135 219 179 184 313 406 73 424 193 459 291 343 434 58 427 92 295 441 83 285 87 397 499 493 500 498 449 494 497 490 451 483...
result:
ok ok (10 test cases)
Test #13:
score: 5
Accepted
time: 18ms
memory: 8648kb
input:
10 100 55 94 8 91 69 56 99 10 29 79 49 39 40 78 57 26 35 28 92 45 66 51 15 82 44 9 41 60 18 67 11 81 90 27 2 36 34 59 73 23 20 95 58 3 22 84 54 87 16 63 52 88 38 80 55 1 96 14 24 17 89 21 83 53 64 71 30 85 98 74 25 31 46 70 94 13 77 86 93 61 6 7 75 19 62 42 4 33 47 50 100 48 5 32 97 68 25 10 39 68 5...
output:
Yes 8 91 69 56 99 10 29 79 49 39 40 78 57 26 35 28 92 45 66 51 15 82 44 9 41 60 18 67 11 81 90 27 2 36 34 59 73 23 20 95 58 3 22 84 54 87 16 63 52 88 38 80 55 1 96 14 24 17 89 21 83 53 64 71 30 85 98 74 25 31 46 70 94 13 77 86 93 61 6 7 75 19 62 42 4 33 47 50 100 48 5 32 97 68 76 37 72 43 65 12 25 1...
result:
ok ok (10 test cases)
Test #14:
score: 5
Accepted
time: 19ms
memory: 8756kb
input:
10 100 4 18 31 65 89 37 67 58 8 48 40 92 12 68 15 98 88 29 43 24 16 30 49 22 4 66 98 81 34 79 8 85 53 23 77 12 67 95 62 48 44 5 69 25 74 68 87 21 99 50 94 82 64 57 19 33 84 40 32 76 52 18 61 28 26 60 83 59 41 11 10 46 91 78 100 92 87 48 8 18 45 5 89 75 79 96 19 41 53 73 42 36 46 94 31 69 20 98 13 83...
output:
Yes 31 65 89 37 67 58 8 48 40 92 12 68 15 98 88 29 43 24 100 99 97 86 2 5 3 1 4 9 11 6 7 16 17 18 19 20 10 14 23 25 21 26 22 30 32 27 34 13 36 38 28 35 42 44 45 46 47 49 50 51 52 53 41 39 55 57 59 60 61 62 63 64 66 69 70 71 72 73 74 33 76 75 78 77 56 81 82 83 79 80 54 87 85 91 93 94 95 90 96 84 16 3...
result:
ok ok (10 test cases)
Test #15:
score: 5
Accepted
time: 271ms
memory: 9188kb
input:
10 300 44 46 113 257 78 212 276 158 253 150 210 278 127 237 40 149 30 63 294 143 239 49 231 70 176 111 213 203 256 192 35 69 68 250 21 23 94 41 288 171 65 126 236 44 289 137 53 129 290 230 271 87 84 251 243 127 279 48 14 174 17 194 191 154 228 297 3 82 86 195 278 143 98 241 137 20 239 30 224 100 169...
output:
Yes 113 257 78 212 276 158 253 150 210 278 127 237 40 149 30 63 294 143 239 49 231 70 176 111 213 203 256 192 35 69 68 250 21 23 94 41 288 171 65 126 236 44 289 137 53 129 300 299 254 298 296 270 293 275 295 297 286 282 218 292 261 246 248 238 147 235 196 242 287 273 207 284 274 230 283 281 249 262 ...
result:
ok ok (10 test cases)
Test #16:
score: 5
Accepted
time: 375ms
memory: 9252kb
input:
10 300 188 74 150 99 240 206 215 91 127 278 69 254 229 266 211 180 205 183 270 198 261 1 48 258 231 148 280 159 21 225 237 109 54 196 77 284 89 189 233 247 217 257 193 291 42 221 213 15 163 14 121 245 26 66 52 218 166 236 139 62 103 242 182 101 234 174 288 59 300 111 144 223 72 216 9 41 10 278 32 19...
output:
Yes 150 99 240 206 215 91 127 278 69 254 229 266 211 180 205 183 270 198 261 1 48 258 231 148 280 159 21 225 237 109 54 196 77 284 89 189 233 247 217 257 193 291 42 221 213 15 163 14 121 245 26 66 52 218 166 236 139 62 103 242 182 101 234 174 288 59 300 111 144 223 72 216 9 41 299 298 290 297 276 29...
result:
ok ok (10 test cases)
Test #17:
score: 5
Accepted
time: 1102ms
memory: 10232kb
input:
10 500 137 394 193 219 137 113 369 248 464 74 408 167 383 399 482 149 154 147 6 50 69 440 437 29 286 427 307 141 228 373 296 244 273 428 44 266 341 173 255 487 114 332 416 405 367 312 323 163 133 339 20 170 26 67 96 195 241 14 205 233 291 179 478 235 381 151 185 469 82 473 441 421 311 118 350 404 23...
output:
Yes 193 219 137 113 369 248 464 74 408 167 383 399 482 149 154 147 6 50 69 440 437 29 286 427 307 141 228 373 296 244 273 428 44 266 341 173 255 487 114 332 416 405 367 312 323 163 133 339 20 170 26 67 96 195 241 14 205 233 291 179 478 235 381 151 185 469 82 473 441 421 311 118 350 404 230 218 472 3...
result:
ok ok (10 test cases)
Test #18:
score: 5
Accepted
time: 1201ms
memory: 10476kb
input:
10 500 481 22 422 263 216 135 73 497 183 188 119 498 338 39 111 113 469 372 274 348 15 456 459 82 21 98 209 76 360 5 481 198 153 147 138 278 131 330 270 350 293 492 426 95 468 27 225 47 65 467 473 440 279 352 475 248 17 33 456 210 70 421 55 208 46 464 277 314 15 426 427 25 300 30 150 417 306 448 492...
output:
Yes 422 263 216 135 73 497 183 188 119 498 338 39 111 113 469 372 274 348 15 456 459 82 500 499 496 127 61 157 282 7 495 475 21 482 86 481 489 224 106 484 487 155 228 291 231 133 199 241 471 95 205 57 112 185 349 432 403 431 261 355 74 486 14 191 122 178 105 152 466 400 450 156 434 65 9 393 126 217 ...
result:
ok ok (10 test cases)
Test #19:
score: 5
Accepted
time: 1121ms
memory: 10432kb
input:
10 500 30 446 375 376 479 293 237 104 108 215 262 4 444 241 436 121 443 195 50 166 234 165 285 315 412 469 92 159 302 44 252 9 392 487 3 495 28 96 341 253 466 352 365 32 176 401 483 60 247 8 58 371 143 68 158 201 364 42 381 240 22 272 427 183 306 235 66 144 438 138 437 208 52 122 174 209 15 102 445 ...
output:
Yes 375 376 479 293 237 104 108 215 262 4 444 241 436 121 443 195 50 166 234 165 285 315 412 469 92 159 302 44 252 9 392 487 3 495 28 96 341 253 466 352 365 32 176 401 483 60 247 8 58 371 143 68 158 201 364 42 381 240 22 272 427 183 306 235 66 144 438 138 437 208 52 122 174 209 15 102 445 428 465 85...
result:
ok ok (10 test cases)
Test #20:
score: 5
Accepted
time: 1034ms
memory: 9904kb
input:
10 500 204 440 401 43 120 246 337 382 241 103 329 272 343 439 9 435 159 355 468 281 333 54 158 479 106 88 50 288 204 412 317 70 78 446 121 238 458 338 230 239 313 263 237 249 115 27 56 107 282 132 117 74 32 113 84 105 413 102 371 184 12 148 373 262 83 29 283 331 209 134 125 67 60 147 459 82 270 316 ...
output:
Yes 401 43 120 246 337 382 241 103 329 272 343 439 9 435 159 355 468 281 333 54 158 479 106 88 50 288 204 412 317 70 78 446 121 238 458 338 230 239 313 263 237 249 115 27 56 107 282 132 117 74 32 113 84 105 413 102 371 184 12 148 373 262 83 29 283 331 209 134 125 67 60 147 459 82 270 316 244 3 4 28 ...
result:
ok ok (10 test cases)