QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#703294#9537. Chinese Chessucup-team5657#RE 292ms4724kbC++205.1kb2024-11-02 17:31:292024-11-02 17:31:31

Judging History

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

  • [2024-11-02 17:31:31]
  • 评测
  • 测评结果:RE
  • 用时:292ms
  • 内存:4724kb
  • [2024-11-02 17:31:29]
  • 提交

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) {
	return st.count();
}
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: 25ms
memory: 4448kb

input:

1
9 0
8

output:

1
? 1 8
! S

result:

ok number is guessed.

Test #2:

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

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: 91ms
memory: 4400kb

input:

1
2 4
-1
1

output:

2
? 0 0
? 0 2
! X

result:

ok number is guessed.

Test #4:

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

input:

1
5 0
6

output:

1
? 3 6
! S

result:

ok number is guessed.

Test #5:

score: 0
Accepted
time: 24ms
memory: 4436kb

input:

1
6 0
6

output:

1
? 0 2
! S

result:

ok number is guessed.

Test #6:

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

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: 217ms
memory: 4724kb

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

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: 273ms
memory: 4468kb

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: 292ms
memory: 4424kb

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: 253ms
memory: 4464kb

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: 238ms
memory: 4724kb

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

result: