QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#703451#9537. Chinese Chessucup-team5657#WA 273ms4720kbC++205.4kb2024-11-02 17:49:112024-11-02 17:49:13

Judging History

你现在查看的是最新测评结果

  • [2024-11-02 17:49:13]
  • 评测
  • 测评结果:WA
  • 用时:273ms
  • 内存:4720kb
  • [2024-11-02 17:49:11]
  • 提交

answer

#pragma GCC optimize("Ofast,no-stack-protector,unroll-loops,fast-math")
#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;
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, tmp.count());
			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(30, int(S.size())); ++i) { int u = S[i].second, mx = 0;
		if(L <= 2) {
			int w;
			vector<pii> v; _rep(j,0,89) if(tmp = st & F[u][j], w = tmp.count(); w) v.emplace_back(w, j);
			sort(v.begin(), v.end(), greater<pii>());
			_rep(j,0,min(10, int(v.size()) - 1)) {
				chkmax(mx, dfs(st & F[u][v[j].second], L + 1));
				if(mx >= 3 - L - 1) break;
			}
		} else {
			_rep(j,0,89) {
				tmp = st & F[u][j]; int v = tmp.count(); if(v) {
					_rep(t,0,5) {
						int a = (tmp & msk[t]).count();
						if(a && a < v) mx = 100000000;
					}
				}
			}
		}
		chkmin(mn, mx); if(!mn) break;
	}
	return mn + 1;
}
int ans ;
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, tmp.count());
			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(30, int(S.size())); ++i) { int u = S[i].second, mx = 0;
		if(L <= 2) {
			int w;
			vector<pii> v; _rep(j,0,89) if(tmp = st & F[u][j], w = tmp.count(); w) v.emplace_back(w, j);
			sort(v.begin(), v.end(), greater<pii>());
			_rep(j,0,min(10, int(v.size()) - 1)) {
				chkmax(mx, dfs(st & F[u][v[j].second], L + 1));
				if(mx >= 3 - L - 1) break;
			}
		} else {
			_rep(j,0,89) {
				tmp = st & F[u][j]; int v = tmp.count(); if(v) {
					_rep(t,0,5) {
						int a = (tmp & msk[t]).count();
						if(a && a < v) mx = 100000000;
					}
				}
			}
		}
		if(mx == ans - L - 1) {
			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(ans = 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
*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 23ms
memory: 4720kb

input:

1
9 0
8

output:

1
? 1 8
! S

result:

ok number is guessed.

Test #2:

score: 0
Accepted
time: 59ms
memory: 4424kb

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: 34ms
memory: 4444kb

input:

1
2 4
-1
1

output:

2
? 0 0
? 0 2
! X

result:

ok number is guessed.

Test #4:

score: 0
Accepted
time: 18ms
memory: 4440kb

input:

1
5 0
6

output:

1
? 3 6
! S

result:

ok number is guessed.

Test #5:

score: 0
Accepted
time: 23ms
memory: 4376kb

input:

1
6 0
6

output:

1
? 0 2
! S

result:

ok number is guessed.

Test #6:

score: 0
Accepted
time: 41ms
memory: 4424kb

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: 141ms
memory: 4708kb

input:

5
8 6
1 3
0 5
2 4
0 2
10
2

output:

2
? 9 3
? 0 0
! J

result:

ok number is guessed.

Test #8:

score: 0
Accepted
time: 110ms
memory: 4420kb

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: 119ms
memory: 4508kb

input:

7
6 5
3 0
3 2
4 1
4 0
2 4
5 2
11
4

output:

2
? 7 8
? 0 0
! J

result:

ok number is guessed.

Test #10:

score: 0
Accepted
time: 115ms
memory: 4708kb

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: 83ms
memory: 4428kb

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: 190ms
memory: 4380kb

input:

10
4 0
0 0
5 0
7 0
8 0
1 0
6 0
9 0
2 0
3 0
9
-1

output:

2
? 9 0
? 0 1
! B

result:

ok number is guessed.

Test #13:

score: 0
Accepted
time: 91ms
memory: 4720kb

input:

9
1 8
1 2
1 5
1 6
1 3
1 4
1 0
1 1
1 7
11
8

output:

2
? 7 2
? 0 0
! J

result:

ok number is guessed.

Test #14:

score: 0
Accepted
time: 273ms
memory: 4452kb

input:

10
0 4
5 4
8 4
2 4
4 4
7 4
3 4
9 4
6 4
1 4
11
5

output:

2
? 9 1
? 0 0
! J

result:

ok number is guessed.

Test #15:

score: 0
Accepted
time: 101ms
memory: 4428kb

input:

9
4 6
4 5
4 7
4 4
4 1
4 3
4 0
4 8
4 2
11
12

output:

2
? 8 1
? 0 0
! J

result:

ok number is guessed.

Test #16:

score: 0
Accepted
time: 202ms
memory: 4520kb

input:

10
9 2
5 2
1 2
8 2
6 2
7 2
2 2
0 2
4 2
3 2
9
-1

output:

2
? 9 2
? 0 0
! B

result:

ok number is guessed.

Test #17:

score: 0
Accepted
time: 96ms
memory: 4500kb

input:

9
3 1
3 7
3 5
3 3
3 6
3 4
3 0
3 2
3 8
11
10

output:

2
? 9 2
? 0 0
! J

result:

ok number is guessed.

Test #18:

score: 0
Accepted
time: 196ms
memory: 4428kb

input:

10
5 1
8 1
6 1
4 1
3 1
0 1
2 1
7 1
9 1
1 1
9
-1

output:

2
? 9 1
? 0 0
! B

result:

ok number is guessed.

Test #19:

score: 0
Accepted
time: 98ms
memory: 4712kb

input:

9
1 6
1 4
1 3
1 7
1 8
1 5
1 2
1 1
1 0
11
8

output:

2
? 7 2
? 0 0
! J

result:

ok number is guessed.

Test #20:

score: 0
Accepted
time: 194ms
memory: 4448kb

input:

10
5 0
9 0
1 0
2 0
3 0
6 0
7 0
4 0
0 0
8 0
9
-1

output:

2
? 9 0
? 0 1
! B

result:

ok number is guessed.

Test #21:

score: 0
Accepted
time: 93ms
memory: 4424kb

input:

9
0 3
0 5
0 7
0 0
0 4
0 8
0 1
0 6
0 2
11
7

output:

2
? 6 2
? 0 0
! J

result:

ok number is guessed.

Test #22:

score: 0
Accepted
time: 195ms
memory: 4424kb

input:

10
1 0
9 0
4 0
2 0
8 0
7 0
5 0
3 0
0 0
6 0
9
-1

output:

2
? 9 0
? 0 1
! B

result:

ok number is guessed.

Test #23:

score: 0
Accepted
time: 97ms
memory: 4720kb

input:

9
1 8
1 2
1 7
1 0
1 4
1 6
1 1
1 5
1 3
11
8

output:

2
? 7 2
? 0 0
! J

result:

ok number is guessed.

Test #24:

score: 0
Accepted
time: 271ms
memory: 4420kb

input:

10
2 4
1 4
0 4
6 4
4 4
9 4
5 4
3 4
7 4
8 4
11
5

output:

2
? 9 1
? 0 0
! J

result:

ok number is guessed.

Test #25:

score: 0
Accepted
time: 92ms
memory: 4676kb

input:

9
0 2
0 7
0 5
0 4
0 0
0 3
0 1
0 6
0 8
11
7

output:

2
? 6 2
? 0 0
! J

result:

ok number is guessed.

Test #26:

score: 0
Accepted
time: 255ms
memory: 4424kb

input:

10
5 3
2 3
3 3
8 3
9 3
1 3
6 3
7 3
0 3
4 3
11
4

output:

2
? 9 0
? 0 0
! J

result:

ok number is guessed.

Test #27:

score: 0
Accepted
time: 219ms
memory: 4680kb

input:

50
7 5
9 2
0 4
9 3
8 4
8 2
7 2
6 4
4 4
0 0
1 7
1 1
1 5
2 0
9 8
9 0
3 1
7 8
8 6
5 0
7 3
8 5
2 6
4 8
3 5
6 8
0 8
5 7
4 6
1 6
3 8
5 6
3 0
5 3
0 7
5 1
3 4
0 1
7 6
2 3
4 3
5 5
8 1
0 3
6 5
9 5
5 8
7 4
6 3
2 7
4
-1
3

output:

3
? 9 3
? 2 6
? 7 5
! X

result:

ok number is guessed.

Test #28:

score: 0
Accepted
time: 219ms
memory: 4520kb

input:

49
4 2
8 0
2 4
9 5
8 1
7 8
0 2
4 7
3 0
1 3
6 6
0 8
8 3
5 8
2 2
1 0
6 0
2 6
0 5
9 2
7 0
4 4
8 8
9 6
5 0
6 8
9 4
7 6
9 0
2 7
4 6
7 7
0 1
4 0
6 7
2 8
8 2
3 2
3 1
3 4
5 4
7 3
5 6
5 2
1 8
3 3
1 7
0 3
4 3
3
6
5

output:

3
? 9 0
? 0 0
? 0 1
! M

result:

ok number is guessed.

Test #29:

score: 0
Accepted
time: 218ms
memory: 4428kb

input:

48
6 7
3 5
0 3
5 7
1 6
9 6
6 2
0 7
5 5
0 4
0 5
0 8
6 4
4 2
8 5
1 2
1 3
8 1
2 7
0 2
2 6
7 1
6 5
0 1
3 7
6 8
7 4
3 3
5 4
5 1
4 4
8 8
7 5
0 0
1 0
7 6
7 7
3 0
7 8
4 0
9 2
9 7
6 6
2 1
6 1
5 2
5 6
4 1
3
-1
7

output:

3
? 9 2
? 2 6
? 1 2
! S

result:

ok number is guessed.

Test #30:

score: 0
Accepted
time: 216ms
memory: 4424kb

input:

51
0 8
1 6
5 3
2 6
9 0
4 0
8 1
0 7
1 0
2 4
8 4
3 6
7 1
8 6
9 7
0 6
5 4
3 2
6 6
7 7
6 1
5 0
4 5
4 8
6 8
3 5
5 8
5 5
8 7
9 6
6 0
3 3
2 3
3 1
2 8
4 4
6 4
1 7
7 2
8 0
3 0
8 8
3 7
1 3
5 6
7 4
6 5
2 7
1 1
7 6
3 8
3
-1
6

output:

3
? 9 3
? 0 0
? 9 0
! B

result:

ok number is guessed.

Test #31:

score: 0
Accepted
time: 219ms
memory: 4448kb

input:

52
1 6
3 8
0 6
9 2
6 4
5 4
2 1
1 0
4 2
2 2
3 2
9 6
7 1
0 2
8 7
1 4
3 1
8 0
3 0
5 8
1 5
7 4
5 7
5 1
6 8
1 2
9 0
6 5
0 4
4 0
5 5
5 0
2 6
6 2
8 5
7 0
0 7
5 3
9 3
0 1
3 5
8 1
4 5
4 6
7 5
8 3
7 8
7 2
3 3
2 5
8 8
2 8
3
-1
4

output:

3
? 9 2
? 3 7
? 7 0
! X

result:

ok number is guessed.

Test #32:

score: -100
Wrong Answer
time: 220ms
memory: 4448kb

input:

89
3 1
7 3
3 0
3 5
0 0
1 3
1 1
3 3
8 8
7 7
2 4
7 0
9 3
2 0
3 7
6 6
7 2
7 1
4 4
2 8
1 2
9 4
9 2
3 8
9 5
6 5
3 4
8 0
2 1
0 4
4 2
1 5
4 7
4 3
7 8
5 6
0 8
0 2
8 7
9 0
5 8
9 8
5 4
0 6
0 5
5 5
7 6
5 0
6 0
6 1
1 0
5 2
8 6
7 5
4 5
9 1
1 4
8 4
4 8
4 6
9 7
1 6
5 3
8 5
9 6
3 6
0 1
6 8
1 8
1 7
4 0
0 3
6 7
0 7
2...

output:

3
? 9 0
? 2 4
? 7 6
? 9 2

result:

wrong answer out of query limit m(3).