QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#647216 | #7179. Fischer's Chess Guessing Game | no_RED_no_DEAD | RE | 166ms | 3992kb | C++20 | 3.3kb | 2024-10-17 12:46:07 | 2024-10-17 12:46:08 |
Judging History
answer
#include "bits/stdc++.h"
using namespace std;
using ll = long long;
using ld = long double;
using ull = unsigned long long;
const ll N = 1e6 + 1;
const ll M = 1e9 + 7;
const ll B = 8;
vector<string> v;
set<string> s;
string cur;
void backtrack(ll pos, ll r, ll n, ll b, ll k, ll q) {
if (pos > B) {
ll r1 = 1e18, r2 = -1e18, b1 = 1e18, b2 = -1e18, k1 = -1e18;
for (ll i = 0; i < cur.size(); i ++) {
if (cur[i] == 'R') r1 = min(r1, i), r2 = max(r2, i);
if (cur[i] == 'B') b1 = min(b1, i), b2 = max(b2, i);
if (cur[i] == 'K') k1 = max(k1, i);
}
if (b1 % 2 == b2 % 2) return;
if (r1 > k1 || r2 < k1) return;
s.insert(cur);
return;
}
if (r < 2) cur += 'R', backtrack(pos + 1, r + 1, n, b, k, q), cur.pop_back();
if (n < 2) cur += 'N', backtrack(pos + 1, r, n + 1, b, k, q), cur.pop_back();
if (b < 2) cur += 'B', backtrack(pos + 1, r, n, b + 1, k, q), cur.pop_back();
if (k < 1) cur += 'K', backtrack(pos + 1, r, n, b, k + 1, q), cur.pop_back();
if (q < 1) cur += 'Q', backtrack(pos + 1, r, n, b, k, q + 1), cur.pop_back();
}
ll get(string &a, string &b) {
ll res = 0;
for (int i = 0; i < a.size(); i ++)
if (a[i] == b[i]) res ++;
return res;
}
mt19937_64 rng(static_cast<ll>(std::chrono::duration_cast<std::chrono::nanoseconds>(std::chrono::high_resolution_clock::now().time_since_epoch()).count()));
ll rand(ll l, ll r) {
return uniform_int_distribution<ll>(l, r)(rng);
}
map<string, ll> m;
void doTest(ll testID) {
backtrack(1, 0, 0, 0, 0, 0);
for (auto x: s) v.push_back(x);
ll test = 0;
while (true) {
string s; ll num; cin >> s; if (s == "END") return; cin >> num;
m.clear();
// /*#TEST*/ string real = v[rand(0, v.size() - 1)];
// cout << "Real: " << real << endl;
vector<string> cv = v;
for (int i = 1;; i ++) {
// /*#TEST*/ if (i == 7) {
// cout << real << endl;
// }
assert(i <= 6);
string chs; array<ll, 9> cur = {(ll)1e18, 0, 0, 0, 0, 0, 0, 0, 0};
if (i == 1) chs = v[rand(0, v.size() - 1)];
else {
for (auto x: cv) {
if (m.count(x)) continue; map<ll, ll> pp;
array<ll, 9> tmp = {0, 0, 0, 0, 0, 0, 0, 0, 0}; for (auto y: cv) pp[get(x, y)] ++;
ll j = 0; for (auto [x, y]: pp) tmp[j] = y, j ++;
sort(tmp.begin(), tmp.end(), greater<ll>());
if (tmp < cur) cur = tmp, chs = x;
}
}
cout << chs << endl;
m[chs] ++;
ll req;
cin >> req;
// /*#TEST*/ req = get(real, chs);
if (req == 8) break;
vector<string> nv;
for (auto x: cv)
if (get(x, chs) == req)
nv.push_back(x);
cv = nv;
// cout << cv.size() << endl;
}
// /*#TEST*/ test ++; cout << "Accept test: " << test << endl;
}
}
signed main() {
ios_base::sync_with_stdio(0); cin.tie(0);
int test = 1;
// cin >> test;
for (int _ = 1; _ <= test; _ ++) doTest(_);
}
详细
Test #1:
score: 100
Accepted
time: 2ms
memory: 3992kb
input:
GAME 1 0 0 1 8 END
output:
BNQRNBKR NRBNQKRB RBNKRNBQ RKRBBQNN
result:
ok (c) correct after 1 tests, max moves 4 (1 test case)
Test #2:
score: 0
Accepted
time: 166ms
memory: 3872kb
input:
GAME 1 0 4 4 3 8 GAME 2 1 2 0 0 8 GAME 3 3 1 1 4 3 8 GAME 4 1 3 1 1 4 8 GAME 5 1 2 1 6 8 GAME 6 4 2 2 6 8 GAME 7 2 0 6 4 8 GAME 8 1 0 0 5 8 GAME 9 1 3 3 0 8 GAME 10 6 5 4 5 8 GAME 11 2 1 2 4 8 GAME 12 2 2 3 0 4 8 GAME 13 3 2 6 8 GAME 14 4 3 1 4 8 GAME 15 2 0 3 5 3 8 GAME 16 3 1 6 8 GAME 17 2 5 4 3 8...
output:
NRBNQBKR RKNBBNRQ RKNQBRNB RBNQBKRN RKRBBQNN NBBQRKRN NRKBBRNQ QRBKNBNR NQNRKRBB RKRBBNQN NNRBKRBQ NQRKNBBR BNRNKQRB NRKBBNRQ BRKBNRNQ RKRBBNNQ BNRNKBQR RQKBBNNR NQBBNRKR RQNNBKRB BRKBQNRN RKRBQNBN NQRNBKRB RNQNKBBR QNBBRKNR RKRBNNBQ RKRBNQBN RKBRNNQB RKBNRBQN RNBQKNRB RKQBNNBR RKRBNNBQ QRNKRBBN NRK...
result:
ok (c) correct after 96 tests, max moves 6 (96 test cases)
Test #3:
score: -100
Runtime Error
input:
GAME 1 3 4 5 8 GAME 2 2 1 2 4 8 GAME 3 1 3 4 3 8 GAME 4 1 3 5 3 8 GAME 5 1 4 4 2 8 GAME 6 4 2 2 8 GAME 7 0 2 3 1 8 GAME 8 4 1 6 8 GAME 9 0 4 6 4 8 GAME 10 2 5 4 3 8 GAME 11 3 3 2 8 GAME 12 2 3 0 2 3 8 GAME 13 2 3 0 3 5 8 GAME 14 2 2 3 6 8 GAME 15 0 4 0 8 GAME 16 2 1 0 8 GAME 17 2 1 5 3 3 8 GAME 18 0...
output:
RQNNBBKR RQKBBNRN RBKQBNNR RKQBBNNR RKBNRBQN NRBQNBKR RBKNQNBR RKNQBNRB RKNBBQNR QRKNBBRN NBNRBQKR BRNBQNKR RBBNQNKR RKNBBNQR BBRKNRQN RKBNNQRB RKNQNBBR RKNNBBQR RKQBNNBR RNBKRBNQ RBNQBNKR RBQNKNBR BBRQKNNR RKNBQNBR RKQBRNBN RKQNBBRN RKBQRNNB RKNBNQBR NRNKRQBB RQKBBNRN RBBNQNKR BBRNKNRQ RKQNBBNR QBN...