QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#602977#8719. 后继UESTC_xxx#WA 1ms15920kbC++142.3kb2024-10-01 13:52:362024-10-01 13:52:37

Judging History

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

  • [2024-10-01 13:52:37]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:15920kb
  • [2024-10-01 13:52:36]
  • 提交

answer

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<cstring>
#include<queue>
#include<map>
#define LL long long
using namespace std;
const int mod=998244353;
const int Base=23,Base2=27;
inline int lowbit(int x){return x&(-x);}
inline int Jia(int x){return x>=mod?x-mod:x;}
inline int Jian(int x){return x>=0?x:x+mod;}
int KSM(int a,int b){
	int Ans=1;
	while(b){
		if(b&1)Ans=1LL*Ans*a%mod;
		a=1LL*a*a%mod;
		b>>=1;
	}
	return Ans;
}
inline int read(){
	int k=0,ty=1;
	char ch=getchar();
	while(ch<'0'||ch>'9'){
		if(ch=='-')ty=-1;
		ch=getchar();
	}
	while(ch<='9'&&ch>='0'){
		k=k*10+ch-'0';
		ch=getchar();
	}
	return k*ty;
}
int gcd(int a,int b){
	if(!b)return a;
	return gcd(b,a%b);
}
const int maxn=5e5+5;
int rt=1,all=1,ch[maxn][2],Size[maxn],id[maxn],ID[maxn][2],v[maxn],n,m;
int a[maxn],pos[maxn],DFN,ans[maxn],To[maxn];
void Insert(int x){
	int p=rt,c;
	for(int i=2;i>=0;--i){
		if(a[x]&(1<<i))c=1;
		else c=0;
		if(!ch[p][c])ch[p][c]=++all;
//		ID[p][c]=x;
		if(ch[p][0]&&ch[p][1])v[i]=p;
		p=ch[p][c];
	}
	pos[x]=p;To[p]=x;
}
void dfs(int x){
	id[x]=++DFN;Size[x]=1;
	if(ch[x][0])dfs(ch[x][0]);
	if(ch[x][1])dfs(ch[x][1]);
	Size[x]+=Size[ch[x][0]]+Size[ch[x][1]];
}
int Get(int x,int deep){
	if(deep==-1)return To[x];
	if(ch[x][ans[deep]^1])return Get(ch[x][ans[deep]^1],deep-1);
	return Get(ch[x][ans[deep]],deep-1);
}
void Solve(){
	for(int i=0;i<=30;++i){
//		cout<<i<<'\n';
		if(!v[i])ans[i]=0;
		else {
//			cout<<"SHIT\n";
			int p=v[i];
			int p2=Get(ch[p][0],i-1);
//			cout<<p<<' '<<p2<<'\n';
			cout<<"? "<<p2<<'\n';
			int t,t2=ch[p][1];
			cin>>t;
//			cout<<t<<'\n';
//			cout<<"FAFAFFA\n";
			if(t==-1){
				ans[i]=1;
				continue;
			}
//			cout<<"F1\n";
			t=pos[t];
//			cout<<"F2\n";
			if(id[t2]<=id[t]&&id[t2]+Size[t2]>id[t])ans[i]=0;
			else ans[i]=1;
		}
	}
//	cout<<"FAFAF\n";
	int Ans=0;
	for(int i=30;i>=0;--i){
//		cout<<ans[i]<<'\n';
		Ans=Ans+(ans[i]<<i);
	}
	cout<<"! "<<Ans<<'\n';
}
int main(){
//	n=read();m=read();
	std::ios::sync_with_stdio(false);
//	cin.tie(0);
	cin>>n>>m;
//	cout<<n<<' '<<m<<'\n';
	for(int i=1;i<=n;++i){
		cin>>a[i];
		Insert(i);
	}
//	cout<<"AFA\n";
	dfs(rt);
//	cout<<"FAF\n";
	for(int i=1;i<=m;++i){
		Solve();
	}
	cout.flush();
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 0ms
memory: 15840kb

input:

5 1
1 2 3 4 5
-1
5
5

output:

? 4
? 1
? 1
! 3

result:

ok 1 number(s): "3"

Test #2:

score: 0
Accepted
time: 0ms
memory: 15920kb

input:

1 1
0

output:

! 0

result:

ok 1 number(s): "0"

Test #3:

score: -100
Wrong Answer
time: 1ms
memory: 13820kb

input:

10 10
380864879 387438357 21484978 21099484 375657510 23189485 24467021 379687119 386094773 15156199
1
10
-1
7
3
10
1
5
4
2
7
4
-1
3
10
-1
3
10
4
3
6
2
7
4
8
2
4
9
3
8

output:

? 5
? 9
? 3
! 4
? 5
? 4
? 3
! 3
? 5
? 9
? 3
! 0
? 5
? 4
? 3
! 3
? 5
? 4
? 3
! 3
? 5
? 4
? 3
! 3
? 5
? 4
? 3
! 3
? 5
? 4
? 3
! 3
? 5
? 9
? 3
! 2
? 5
? 4
? 3
! 3

result:

wrong answer 1st numbers differ - expected: '271581184', found: '4'