QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#703290 | #9537. Chinese Chess | ucup-team5657# | RE | 845ms | 4680kb | C++20 | 5.1kb | 2024-11-02 17:30:55 | 2024-11-02 17:30:56 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define _rep(i_,a_,b_) for(int i_ = (a_); i_ <= (b_); ++i_)
#define mid ((L+R) >> 1)
#define multiCase() int testCnt = in(); _rep(curCase,1,testCnt)
#ifdef ONLINE_JUDGE
#define debug(...) 0
#else
#define debug(...) fprintf(stderr, __VA_ARGS__), fflush(stderr)
#endif
using ll = long long;
using pii = pair<int,int>;
using ull = unsigned long long;
const int inf = 0x3f3f3f3f;
const ll inf64 = 0x3f3f3f3f3f3f3f3fll;
int in(void) { int x; scanf("%d", &x); return x; } ll inl(void) { ll x; scanf("%lld", &x); return x; }
void out(int x) { printf("%d ", x); } void outln(int x) { printf("%d\n", x); }
void out(unsigned x) { printf("%u ", x); } void outln(unsigned x) { printf("%u\n", x); }
void out(ll x) { printf("%lld ", x); } void outln(ll x) { printf("%lld\n", x); }
void out(ull x) { printf("%llu ", x); } void outln(ull x) { printf("%llu\n", x); }
template<typename T, typename U> void chkmax(T &a, const U &b) { if(b > a) a = b; }
template<typename T, typename U> void chkmin(T &a, const U &b) { if(b < a) a = b; }
bitset<540> F[90][90], msk[6];
int vis[90][90];
vector<pii> mov[6];
bool check(int x, int y) { return 0 <= x && x <= 9 && 0 <= y && y <= 8; }
void bfs(int x, int y, int t) {
queue<pii> q; q.emplace(x, y);
while(!q.empty()) {
auto [x, y] = q.front(); q.pop();
for(auto &[dx, dy] : mov[t]) {
int nx = x + dx, ny = y + dy;
if(check(nx, ny) && !(t == 5 && !dx && x <= 4) && vis[nx][ny] > vis[x][y]) {
vis[nx][ny] = vis[x][y] + 1;
q.emplace(nx, ny);
}
}
}
}
int flg;
inline int approximate(bitset<540> st) {
int f = st.count() * .4, f2 = 0;
_rep(t,0,5) f2 += (st & msk[t]).count();
return f + f2 * f2;
}
int dfs(bitset<540> st, int L) { bitset<540> tmp;
if(st.count() == 1) return 0;
_rep(t,0,5) if((st & msk[t]).count() == st.count()) return 0;
if(L >= 3) return inf;
vector<pii> S;
_rep(i,0,89) {
int mx = 0, m2x = 0;
_rep(j,0,89) {
if(tmp = st & F[i][j]; tmp.count() != st.count())
chkmax(mx, approximate(tmp));
else { m2x = 1; break; }
}
if(!m2x) S.emplace_back(mx, i);
}
sort(S.begin(), S.end());
int mn = inf;
for(int i = 0; i < min(int(S.size()), L == 0 ? 30 : (L == 2 ? 7 : 3)); ++i) { int u = S[i].second, mx = 0;
vector<pii> v; _rep(j,0,89) if(tmp = st & F[u][j]; tmp.count()) v.emplace_back(approximate(tmp), j);
sort(v.begin(), v.end(), greater<pii>());
_rep(j,0,min(7, int(v.size()) - 1)) {
chkmax(mx, dfs(st & F[u][v[j].second], L + 1));
if(mx >= 3 - L - 1) break;
}
chkmin(mn, mx); if(!mn) break;
}
return mn + 1;
}
void DOIT(bitset<540> st, int L) { bitset<540> tmp;
_rep(t,0,5) {
int cnt = 0;
_rep(i,t * 90, (t + 1) * 90 - 1) cnt += st[i];
if(cnt == st.count()) {
printf("! ");
if(t == 0) puts("J");
if(t == 1) puts("M");
if(t == 2) puts("S");
if(t == 3) puts("X");
if(t == 4) puts("C");
if(t == 5) puts("B");
fflush(stdout);
exit(0);
}
}
vector<pii> S;
_rep(i,0,89) {
int mx = 0, m2x = 0;
_rep(j,0,89) {
if(tmp = st & F[i][j]; tmp.count() != st.count())
chkmax(mx, approximate(tmp));
else { m2x = 1; break; }
}
if(!m2x) S.emplace_back(mx, i);
}
sort(S.begin(), S.end());
int mn = inf;
for(int i = 0; i < min(int(S.size()), L == 0 ? 30 : (L == 2 ? 7 : 3)); ++i) { int u = S[i].second, mx = 0;
vector<pii> v; _rep(j,0,89) if(tmp = st & F[u][j]; tmp.count()) v.emplace_back(approximate(tmp), j);
sort(v.begin(), v.end(), greater<pii>());
_rep(j,0,min(7, int(v.size()) - 1)) {
chkmax(mx, dfs(st & F[u][v[j].second], L + 1));
if(mx >= 3 - L - 1) break;
} S[i].first = mx; chkmin(mn, mx); if(!mn) break;
}
for(int i = 0; i < min(int(S.size()), L == 0 ? 30 : (L == 2 ? 7 : 3)); ++i) if(S[i].first == mn) {
printf("? %d %d\n", S[i].second / 9, S[i].second % 9); fflush(stdout);
int u = in();
DOIT(st & F[S[i].second][u == -1 ? 89 : u], L + 1);
}
}
int main() {
mov[0] = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}}; //J
mov[1] = {{1, 2}, {-1, 2}, {1, -2}, {-1, -2}, {2, 1}, {-2, 1}, {2, -1}, {-2, -1}}; //M
mov[2] = {{1, 1}, {1, -1}, {-1, 1}, {-1, -1}}; //S
mov[3] = {{2, 2}, {-2, 2}, {2, -2}, {-2, -2}}; //X
_rep(i,-9,9) if(i) mov[4].emplace_back(i, 0), mov[4].emplace_back(0, i); //C
mov[5] = {{1, 0}, {0, 1}, {0, -1}}; //B
_rep(t,0,5) _rep(i,0,9) _rep(j,0,8) {
_rep(x,0,9) _rep(y,0,8) vis[x][y] = 89;
vis[i][j] = 0, bfs(i, j, t);
_rep(x,0,9) _rep(y,0,8) F[x * 9 + y][vis[x][y]][t * 90 + i * 9 + j] = 1;
}
_rep(t,0,5) _rep(j,t * 90,(t + 1) * 90 - 1) msk[t][j] = 1;
bitset<540> st;
// st.set();
int n = in();
_rep(i,1,n) {
int x = in(), y = in(), z = x * 9 + y;
_rep(j,0,5) st[j * 90 + z] = 1;
}
outln(dfs(st, 0));
DOIT(st, 0);
return 0;
}
/*
a list of keywords
clear empty push_back pop_back push pop top front back
emplace_back emplace push_front pop_front insert erase
find count set reset bitset map vector string multiset
first second iterator prev next deque multimap reverse
sort begin end list modify query init check calc prime
putchar getchar puts scanf printf max min swap replace
make_pair make_tuple numeric_limits auto function null
*/
详细
Test #1:
score: 100
Accepted
time: 26ms
memory: 4380kb
input:
1 9 0 8
output:
1 ? 1 8 ! S
result:
ok number is guessed.
Test #2:
score: 0
Accepted
time: 446ms
memory: 4380kb
input:
4 2 1 2 3 2 5 2 7 12 9
output:
2 ? 7 0 ? 0 0 ! J
result:
ok number is guessed.
Test #3:
score: 0
Accepted
time: 236ms
memory: 4380kb
input:
1 2 4 -1 1
output:
2 ? 0 0 ? 0 2 ! X
result:
ok number is guessed.
Test #4:
score: 0
Accepted
time: 28ms
memory: 4408kb
input:
1 5 0 6
output:
1 ? 3 6 ! S
result:
ok number is guessed.
Test #5:
score: 0
Accepted
time: 26ms
memory: 4400kb
input:
1 6 0 6
output:
1 ? 0 2 ! S
result:
ok number is guessed.
Test #6:
score: 0
Accepted
time: 369ms
memory: 4336kb
input:
2 7 7 1 0 5 14
output:
2 ? 7 2 ? 0 0 ! J
result:
ok number is guessed.
Test #7:
score: 0
Accepted
time: 631ms
memory: 4680kb
input:
5 8 6 1 3 0 5 2 4 0 2 12 2
output:
2 ? 8 6 ? 0 0 ! J
result:
ok number is guessed.
Test #8:
score: 0
Accepted
time: 659ms
memory: 4332kb
input:
6 0 7 1 6 2 8 0 5 7 6 8 2 14 -1
output:
2 ? 8 1 ? 0 0 ! B
result:
ok number is guessed.
Test #9:
score: 0
Accepted
time: 794ms
memory: 4660kb
input:
7 6 5 3 0 3 2 4 1 4 0 2 4 5 2 11 4
output:
2 ? 8 7 ? 0 0 ! J
result:
ok number is guessed.
Test #10:
score: 0
Accepted
time: 845ms
memory: 4632kb
input:
8 3 3 2 5 6 2 7 4 1 4 3 0 2 4 3 4 6 4
output:
2 ? 7 4 ? 0 1 ! J
result:
ok number is guessed.
Test #11:
score: 0
Accepted
time: 746ms
memory: 4664kb
input:
9 2 7 2 4 2 5 2 2 2 1 2 0 2 6 2 3 2 8 11 9
output:
2 ? 8 2 ? 0 0 ! J
result:
ok number is guessed.
Test #12:
score: 0
Accepted
time: 672ms
memory: 4376kb
input:
10 4 0 0 0 5 0 7 0 8 0 1 0 6 0 9 0 2 0 3 0 16 1
output:
2 ? 9 8 ? 0 0 ! J
result:
ok number is guessed.
Test #13:
score: -100
Runtime Error
input:
9 1 8 1 2 1 5 1 6 1 3 1 4 1 0 1 1 1 7
output:
3 ? 7 2