QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#265704 | #7740. Puzzle: Question Mark | ucup-team1191# | AC ✓ | 283ms | 19024kb | C++20 | 13.2kb | 2023-11-25 20:31:02 | 2023-11-25 20:31:02 |
Judging History
answer
/*
author: Maksim1744
created: 25.11.2023 14:18:46
*/
#include "bits/stdc++.h"
using namespace std;
using ll = long long;
using ld = long double;
#define mp make_pair
#define pb push_back
#define eb emplace_back
#define sum(a) ( accumulate ((a).begin(), (a).end(), 0ll))
#define mine(a) (*min_element((a).begin(), (a).end()))
#define maxe(a) (*max_element((a).begin(), (a).end()))
#define mini(a) ( min_element((a).begin(), (a).end()) - (a).begin())
#define maxi(a) ( max_element((a).begin(), (a).end()) - (a).begin())
#define lowb(a, x) ( lower_bound((a).begin(), (a).end(), (x)) - (a).begin())
#define uppb(a, x) ( upper_bound((a).begin(), (a).end(), (x)) - (a).begin())
template<typename T> vector<T>& operator-- (vector<T> &v){for (auto& i : v) --i; return v;}
template<typename T> vector<T>& operator++ (vector<T> &v){for (auto& i : v) ++i; return v;}
template<typename T> istream& operator>>(istream& is, vector<T> &v){for (auto& i : v) is >> i; return is;}
template<typename T> ostream& operator<<(ostream& os, vector<T> v){for (auto& i : v) os << i << ' '; return os;}
template<typename T, typename U> pair<T,U>& operator-- (pair<T, U> &p){--p.first; --p.second; return p;}
template<typename T, typename U> pair<T,U>& operator++ (pair<T, U> &p){++p.first; ++p.second; return p;}
template<typename T, typename U> istream& operator>>(istream& is, pair<T, U> &p){is >> p.first >> p.second; return is;}
template<typename T, typename U> ostream& operator<<(ostream& os, pair<T, U> p){os << p.first << ' ' << p.second; return os;}
template<typename T, typename U> pair<T,U> operator-(pair<T,U> a, pair<T,U> b){return mp(a.first-b.first, a.second-b.second);}
template<typename T, typename U> pair<T,U> operator+(pair<T,U> a, pair<T,U> b){return mp(a.first+b.first, a.second+b.second);}
template<typename T, typename U> void umin(T& a, U b){if (a > b) a = b;}
template<typename T, typename U> void umax(T& a, U b){if (a < b) a = b;}
#ifdef HOME
#define SHOW_COLORS
#include "/mnt/c/Libs/tools/print.cpp"
#else
#define show(...) void(0)
#define debugf(fun) fun
#define debugv(var) var
#define mclock void(0)
#define shows void(0)
#define debug if (false)
#define OSTREAM(...) ;
#define OSTREAM0(...) ;
#endif
template<class Fun>
class y_combinator_result {
Fun fun_;
public:
template<class T>
explicit y_combinator_result(T &&fun): fun_(std::forward<T>(fun)) {}
template<class ...Args>
decltype(auto) operator()(Args &&...args) {
return fun_(std::ref(*this), std::forward<Args>(args)...);
}
};
template<class Fun>
decltype(auto) y_combinator(Fun &&fun) {
return y_combinator_result<std::decay_t<Fun>>(std::forward<Fun>(fun));
}
// auto gcd = std::y_combinator([](auto gcd, int a, int b) -> int {
// return b == 0 ? a : gcd(b, a % b);
// });
template<size_t N>
bool operator < (const bitset<N>& a, const bitset<N>& b) {
if (a == b) return false;
int ind = (a ^ b)._Find_first();
return b.test(ind);
}
struct Cmp {
template<size_t N>
bool operator () (const bitset<N>& a, const bitset<N>& b) const {
if (a == b) return false;
int ind = (a ^ b)._Find_first();
return b.test(ind);
}
};
int main() {
ios_base::sync_with_stdio(false); cin.tie(NULL);
vector<vector<string>> preps = {
vector<string>{
".AA",
"BAB",
"BBA",
},
vector<string>{
"..AA.",
"BBACC",
".BCAC",
"BDDEE",
".DEDE",
},
vector<string>{
".A.ABB.",
"CCAABDD",
"CECEDBD",
".EEFFGG",
"HH.FGFG",
"HIIJJKK",
"IHIJKJK",
},
vector<string>{
".AABBCCDD",
"EEABCBCDF",
"EAGGHHIFD",
"JEJGHIHFF",
"JJGKKIILL",
"MMKNKNOLO",
"MPQQNNOOL",
"PMQRRSSTT",
"PPRQRSTST",
},
vector<string>{
"ABACCDEEFFGGH",
"BAACDCEFEFGHG",
"BBIIDDJJKKLHH",
"MIMINJNJKLKOO",
"MMPQPNNRRLLOS",
"TTQPPUURVRVSO",
"TWQQXXUYYVVSS",
"WTZZXU[Y[//]]",
"WWZ^^X[[Y/]/]",
"__^Z^``aabbcc",
"_dee.`a`abcbc",
"d_effgghhiijj",
"ddfefghghijij",
},
vector<string>{
"ABAB",
"AABB",
},
vector<string>{
"AA",
"AB",
"BA",
"BB",
},
};
int t;
cin >> t;
while (t--) {
int n;
cin >> n;
int last = 0;
vector<vector<int>> v(n, vector<int>(n, 0));
auto fill_at = [&](int i, int j, int n, int m) {
assert(i + n <= v.size());
assert(j + m <= v.size());
for (const auto& prep : preps) {
if (prep.size() == n && prep[0].size() == m) {
map<char, int> who;
for (int x = 0; x < n; ++x) {
for (int y = 0; y < m; ++y) {
if (prep[x][y] == '.') continue;
if (!who.count(prep[x][y])) {
++last;
who[prep[x][y]] = last;
}
assert(v[x + i][y + j] == 0);
v[x + i][y + j] = who[prep[x][y]];
}
}
return;
}
}
assert(false);
};
auto fill_even = [&](int i, int j, int n, int m) {
assert(n % 2 == 0);
assert(m % 2 == 0);
if (n % 4 == 0) {
for (int x = 0; x < n; x += 4)
for (int y = 0; y < m; y += 2)
fill_at(i+x, y+j, 4, 2);
} else {
assert(m % 4 == 0);
for (int x = 0; x < n; x += 2)
for (int y = 0; y < m; y += 4)
fill_at(i+x, y+j, 2, 4);
}
};
if (n % 2 == 0) {
if (n % 4 == 0) {
for (int i = 0; i < n; i += 2) {
for (int j = 0; j < n; j += 4) {
fill_at(i, j, 2, 4);
}
}
} else {
for (int i = 0; i < n; i += 2) {
for (int j = 0; j + 4 <= n; j += 4) {
fill_at(i, j, 2, 4);
}
}
for (int i = 0; i + 4 <= n; i += 4) {
fill_at(i, n - 2, 4, 2);
}
}
} else {
if (n == 1) {
} else if (n == 3 || n == 5 || n == 7) {
fill_at(0, 0, n, n);
} else {
auto start_from = (n % 8 < 4 ? 9 : 13);
int k = start_from;
fill_at(0, 0, k, k);
while (k + 8 <= n) {
fill_at(k-1, k-1, 9, 9);
fill_even(k, 0, 8, k-1);
fill_even(0, k, k-1, 8);
k += 8;
}
if (k != n) {
fill_at(k-1, k-1, 3, 3);
for (int i = 0; i + 4 <= k; i += 4) {
fill_at(i, k, 4, 2);
fill_at(k, i, 2, 4);
}
}
}
}
cout << last << '\n';
for (int i = 0; i < n; ++i) {
for (int j = 0; j < n; ++j) {
cout << v[i][j] << " \n"[j + 1 == n];
}
}
#ifdef HOUSE
vector<int> cnt(last);
for (int i = 0; i < n; ++i) {
for (int j = 0; j < n; ++j) {
if (v[i][j] != 0)
cnt[v[i][j] - 1]++;
}
}
assert(count(cnt.begin(), cnt.end(), 4) == cnt.size());
cout.flush();
#endif
}
// const int n = 7;
// const int m = 7;
// static_assert(n >= 4);
// static_assert(m >= 4);
// using B = bitset<n * m>;
// auto ind = [&](int i, int j) {
// return i * m + j;
// };
// vector<B> base;
// {
// B square = 0;
// square.set(ind(1, 1));
// square.set(ind(1, 2));
// square.set(ind(2, 1));
// square.set(ind(2, 2));
// {
// auto u = square;
// u.flip(ind(1, 1));
// u.flip(ind(0, 1));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(1, 1));
// u.flip(ind(1, 0));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(1, 2));
// u.flip(ind(1, 3));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(1, 2));
// u.flip(ind(0, 2));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(2, 1));
// u.flip(ind(2, 0));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(2, 1));
// u.flip(ind(3, 1));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(2, 2));
// u.flip(ind(2, 3));
// base.pb(u);
// }
// {
// auto u = square;
// u.flip(ind(2, 2));
// u.flip(ind(3, 2));
// base.pb(u);
// }
// }
// for (auto& x : base) {
// while ((x >> m).count() == 4) x >>= m;
// while (true) {
// bool ok = true;
// for (int i = 0; i < n; ++i) {
// if (x[ind(i, 0)]) {
// ok = false;
// break;
// }
// }
// if (ok) x >>= 1;
// else break;
// }
// }
// // auto print = [&](const B& b) {
// // for (int i = 0; i < n; ++i) {
// // for (int j = 0; j < n; ++j) {
// // cout << ".#"[b[ind(i, j)]];
// // }
// // cout << '\n';
// // }
// // cout << endl;
// // };
// sort(base.begin(), base.end());
// base.erase(unique(base.begin(), base.end()), base.end());
// vector<B> v;
// for (auto b : base) {
// while (true) {
// v.pb(b);
// if ((b << m).count() != 4) break;
// b <<= m;
// }
// }
// swap(v, base);
// v.clear();
// for (auto b : base) {
// while (true) {
// v.pb(b);
// bool ok = true;
// for (int i = 0; i < n; ++i) {
// if (b.test(ind(i, m-1))) {
// ok = false;
// break;
// }
// }
// if (!ok) break;
// b <<= 1;
// }
// }
// swap(v, base);
// sort(base.begin(), base.end());
// // for (auto& x : base)
// // print(x);
// int best = 0;
// map<B, B, Cmp> par;
// vector<B> suf = base;
// for (int i = (int)suf.size() - 2; i >= 0; --i)
// suf[i] |= suf[i + 1];
// best = 0;
// y_combinator([&](auto dfs, B mask, int i) -> void {
// // if (mask.test(0)) return;
// if (mask.count() > best) {
// best = mask.count();
// cout << "new best: " << best << ", empty: " << mask.size() - mask.count() << endl;
// auto ms = mask;
// char c = 'A';
// vector<string> field(n, string(m, '.'));
// while (ms.count()) {
// auto here = ms ^ par[ms];
// for (int i = 0; i < n; ++i) {
// for (int j = 0; j < m; ++j) {
// if (here.test(ind(i, j))) {
// field[i][j] = c;
// }
// }
// }
// ++c;
// ms ^= here;
// }
// for (auto s : field) {
// cout << s << endl;
// }
// }
// if (i == base.size()) return;
// if ((mask | suf[i]).count() <= best) return;
// B other = 0;
// for (int j = i; j < base.size(); ++j)
// if ((mask & base[j]).count() == 0)
// other |= base[j];
// if ((mask | other).count() <= best) return;
// if ((mask & base[i]).count() == 0 && !par.count(mask | base[i])) {
// par[mask | base[i]] = mask;
// dfs(mask | base[i], i + 1);
// }
// dfs(mask, i + 1);
// })(B{0}, 0);
return 0;
}
这程序好像有点Bug,我给组数据试试?
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3832kb
input:
2 3 4
output:
2 0 1 1 2 1 2 2 2 1 4 1 2 1 2 1 1 2 2 3 4 3 4 3 3 4 4
result:
ok Correct. (2 test cases)
Test #2:
score: 0
Accepted
time: 243ms
memory: 3912kb
input:
246 1 2 3 4 5 6 7 8 9 10 11 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 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 ...
output:
0 0 0 0 0 0 0 2 0 1 1 2 1 2 2 2 1 4 1 2 1 2 1 1 2 2 3 4 3 4 3 3 4 4 5 0 0 1 1 0 2 2 1 3 3 0 2 3 1 3 2 4 4 5 5 0 4 5 4 5 8 1 2 1 2 7 7 1 1 2 2 7 8 3 4 3 4 8 7 3 3 4 4 8 8 5 6 5 6 0 0 5 5 6 6 0 0 11 0 1 0 1 2 2 0 3 3 1 1 2 4 4 3 5 3 5 4 2 4 0 5 5 6 6 7 7 8 8 0 6 7 6 7 8 9 9 10 10 11 11 9 8 9 10 11 10 ...
result:
ok Correct. (246 test cases)
Test #3:
score: 0
Accepted
time: 256ms
memory: 4232kb
input:
64 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310
output:
15252 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 1655...
result:
ok Correct. (64 test cases)
Test #4:
score: 0
Accepted
time: 266ms
memory: 3704kb
input:
45 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355
output:
24180 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 1655...
result:
ok Correct. (45 test cases)
Test #5:
score: 0
Accepted
time: 240ms
memory: 3928kb
input:
35 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390
output:
31684 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 52 ...
result:
ok Correct. (35 test cases)
Test #6:
score: 0
Accepted
time: 229ms
memory: 4020kb
input:
30 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420
output:
38220 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 1655...
result:
ok Correct. (30 test cases)
Test #7:
score: 0
Accepted
time: 248ms
memory: 18864kb
input:
2 2000 1000
output:
1000000 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 5...
result:
ok Correct. (2 test cases)
Test #8:
score: 0
Accepted
time: 283ms
memory: 18960kb
input:
2 1999 999
output:
999000 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 165...
result:
ok Correct. (2 test cases)
Test #9:
score: 0
Accepted
time: 249ms
memory: 19024kb
input:
2 1998 998
output:
998000 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 52...
result:
ok Correct. (2 test cases)
Test #10:
score: 0
Accepted
time: 248ms
memory: 18952kb
input:
2 1997 997
output:
997002 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 165...
result:
ok Correct. (2 test cases)
Test #11:
score: 0
Accepted
time: 249ms
memory: 18640kb
input:
2 1996 996
output:
996004 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 52...
result:
ok Correct. (2 test cases)
Test #12:
score: 0
Accepted
time: 268ms
memory: 18760kb
input:
2 1995 995
output:
995006 0 1 1 2 2 3 3 4 4 57 57 59 59 61 61 63 63 125 125 127 127 129 129 131 131 225 225 227 227 229 229 231 231 357 357 359 359 361 361 363 363 521 521 523 523 525 525 527 527 717 717 719 719 721 721 723 723 945 945 947 947 949 949 951 951 1205 1205 1207 1207 1209 1209 1211 1211 1497 1497 1499 1499...
result:
ok Correct. (2 test cases)
Test #13:
score: 0
Accepted
time: 247ms
memory: 18616kb
input:
2 1994 994
output:
994008 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 52...
result:
ok Correct. (2 test cases)
Test #14:
score: 0
Accepted
time: 264ms
memory: 18616kb
input:
2 1993 993
output:
993012 0 1 1 2 2 3 3 4 4 57 57 59 59 61 61 63 63 125 125 127 127 129 129 131 131 225 225 227 227 229 229 231 231 357 357 359 359 361 361 363 363 521 521 523 523 525 525 527 527 717 717 719 719 721 721 723 723 945 945 947 947 949 949 951 951 1205 1205 1207 1207 1209 1209 1211 1211 1497 1497 1499 1499...
result:
ok Correct. (2 test cases)
Test #15:
score: 0
Accepted
time: 251ms
memory: 18668kb
input:
2 1992 992
output:
992016 1 2 1 2 3 4 3 4 5 6 5 6 7 8 7 8 9 10 9 10 11 12 11 12 13 14 13 14 15 16 15 16 17 18 17 18 19 20 19 20 21 22 21 22 23 24 23 24 25 26 25 26 27 28 27 28 29 30 29 30 31 32 31 32 33 34 33 34 35 36 35 36 37 38 37 38 39 40 39 40 41 42 41 42 43 44 43 44 45 46 45 46 47 48 47 48 49 50 49 50 51 52 51 52...
result:
ok Correct. (2 test cases)
Test #16:
score: 0
Accepted
time: 264ms
memory: 18700kb
input:
2 1991 991
output:
991020 1 2 1 3 3 4 5 5 6 6 7 7 8 87 87 89 89 91 91 93 93 171 171 173 173 175 175 177 177 287 287 289 289 291 291 293 293 435 435 437 437 439 439 441 441 615 615 617 617 619 619 621 621 827 827 829 829 831 831 833 833 1071 1071 1073 1073 1075 1075 1077 1077 1347 1347 1349 1349 1351 1351 1353 1353 165...
result:
ok Correct. (2 test cases)
Extra Test:
score: 0
Extra Test Passed