Submission #225342

#TimeUsernameProblemLanguageResultExecution timeMemory
225342kshitij_sodaniLibrary (JOI18_library)C++17
0 / 100
589 ms636 KiB
#include <iostream> #include <bits/stdc++.h> #include "library.h" using namespace std; #define pb push_back typedef long long llo; #define a first #define b second int n; vector<int> aa; vector<int> bb; /* void Answer(vector<int> cc){ for(auto j:cc) { cout<<j<<" "; } cout<<endl; } int Query(vector<int> cc){ for(auto j:cc){ cout<<j<<" "; } cout<<endl; int xx; cin>>xx; return xx; }*/ int ll; void solve(int ind,int l,int r){ //cout<<l<<" "<<r<<endl; if(l==r){ ll=l; return; if(aa[l]==0){ ll=-1; return ; } /* if(ind==l){ ll=-1; while(true){ continue; } } else{*/ for(int i=0;i<n;i++){ if((ind==i or i==l)){ bb[i]=1; } else{ bb[i]=0; } } int yy=Query(bb); if(yy==1){ aa[l]=0; ll=l; } else{ ll=-1; } //} } else{ int mid=(l+r)/2; int co=0; for(int i=0;i<n;i++){ bb[i]=0; } for(int i=l;i<=mid;i++){ if(aa[i]==2){ bb[i]=1; co+=1; } } if(co==0){ solve(ind,mid+1,r); } else{ bb[ind]=1; int yy=Query(bb); bb[ind]=0; int zz=Query(bb); if(yy==zz){ solve(ind,l,mid); } else{ co=0; for(int i=0;i<n;i++){ bb[i]=0; } for(int i=mid+1;i<=r;i++){ if(aa[i]==2){ bb[i]=1; co+=1; } } if(co==0){ ll=-1; return ; } bb[ind]=1; yy=Query(bb); bb[ind]=0; zz=Query(bb); if(yy==zz){ solve(ind,mid+1,r); } else{ ll=-1; } } } } } void Solve(int nn){ n=nn; for(int i=0;i<n;i++){ aa.pb(2); bb.pb(0); } int x=0; deque<int> ans; ans.push_back(0); int st=0; int kk=0; int le=n-1; aa[0]=0; int cco=0; while(le and cco<3*n){ cco+=1; int y=x; ll=-2; solve(x,0,n-1); if(ll==y){ while(true){ continue; } } if(ll!=-1){ le-=1; } if(ll==-2){ while(true){ continue; } } x=ll; if(x==-1){ x=0; st=1; kk+=1; } else{ if(st==0){ ans.push_back(x); } else{ ans.push_front(x); } } aa[x]=0; aa[y]=0; } vector<int> fin; for(int i=0;i<n;i++){ int x=ans.front(); ans.pop_front(); fin.pb(x+1); } Answer(fin); } /*int main(){ ios_base::sync_with_stdio(false); cin.tie(NULL); Solve(3); return 0; }*/
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...