#include<bits/stdc++.h>
using namespace std;
#define F first
#define S second
#define pll pair<ll, ll>
#define vll vector<ll>
#define pb push_back
typedef long long ll;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
ll B;
ll rand(ll a, ll b){
	return rng()%(b-a+1)+a;
}
ll n, t;
double p;
bool qry(string s){
	cout<<"Q "<<s<<endl;
	char re;
	cin>>re;
	if(re=='P') return true;
	return false;
}
void ans(string s){
	cout<<"A "<<s<<endl;
	char re;
	cin>>re;
}
string mrg(string a, string b){
	string re;
	for(ll i=0;i<n;i++){
		if(a[i]=='1' || b[i]=='1') re+='1';
		else re+='0';
	}
	return re;
}
bool check(string s){
	for(ll i=0;i<n;i++){
		if(s[i]=='1') return true;
	}
	return false;
}
string f(ll lef, ll rig, bool exist){
	if(lef>rig){
		string tep;
		for(ll i=0;i<n;i++){
			tep+='0';
		}
		return tep;
	}
	double stupid=(double) (rig-lef+1)*p;
	if(stupid<5){
		vector<bool> v(n);
		auto ff=[&](ll tar){
			string tep;
			for(ll i=0;i<n;i++){
				if(i>=lef && i<=rig && i<=tar && !v[i]){
					tep+='1';
				}
				else{
					tep+='0';
				}
			}
			return qry(tep);
		};	
		ll pre=lef-1;
		while(pre<rig){
			ll l=pre+1, r=rig;
			ll good=-1;
			while(l<=r){
				ll mid=(l+r)/2;
				if(ff(mid)){
					good=mid;
					r=mid-1;
				}
				else{
					l=mid+1;
				}
			}
			if(good==-1) break;
			v[good]=1;
			pre=good;
		}
		string tep;
		for(ll i=0;i<n;i++){
			if(v[i]) tep+='1';
			else tep+='0';
		}
		// ans(tep);
		return tep;
	}
	string tep;
	for(ll i=0;i<n;i++){
		if(i>=lef && i<=rig){
			tep+='1';
		}
		else{
			tep+='0';
		}
	}
	bool re;
	if(!exist) re=qry(tep);
	else re=1;
	if(!re){
		string tep;
		for(ll i=0;i<n;i++){
			tep+='0';
		}
		return tep;
	}
	if(lef==rig){
		string tep;
		for(ll i=0;i<n;i++){
			if(i==lef) tep+='1';
			else tep+='0';
		}
		return tep;
	}
	
	// if(rig-lef+1==2){
		ll mid=(lef+rig)/2;
		if(rand(0, 1)==0){
			string tep1=f(lef, mid, 0);
			bool dumb=0;
			if(!check(tep1)) dumb=1;
			string tep2=f(mid+1, rig, dumb);
			return mrg(tep1, tep2);
		}
		else{
			string tep2=f(mid+1, rig, 0);
			bool dumb=0;
			if(!check(tep2)) dumb=1;
			string tep1=f(lef, mid, dumb);
			return mrg(tep1, tep2);
		}
	// }
	// else{
	// 	ll diff=(rig-lef)/3;
	// 	ll mid1=lef+diff;
	// 	ll mid2=rig-diff;
	// 	string tep1=f(lef, mid1, 0);
	// 	string tep2=f(mid1+1, mid2-1, 0);
	// 	bool dumb=0;
	// 	if(!check(tep1) && !check(tep2)) dumb=1;
	// 	string tep3=f(mid2, rig, dumb);
	// 	return mrg(mrg(tep1, tep2), tep3);
	// }
	
	
}
void solve(){
	string s;
	for(ll i=0;i<n;i++) s+='1';
	bool dumb=qry(s);
	if(!dumb){
		s="";
		for(ll i=0;i<n;i++) s+='0';
		ans(s);
		return;
	}
	string a;
	for(ll i=0;i<n;i++){
		a+='0';
	}
	for(ll i=0;i<n;i+=B){
		string tep;
		for(ll j=0;j<n;j++){
			if(j-i>=0 && j-i<B) tep+='1';
			else tep+='0';
		}
		if(qry(tep)){
			string tep2=f(i, min(i+B-1, n-1), 1);
			a=mrg(a, tep2);
		}
	}
	ans(a);
}
int main(){
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>p>>t;
	B=round((double) 1/p)+3;
	while(t--){
		solve();
	}
	return 0;
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |