제출 #225280

#제출 시각아이디문제언어결과실행 시간메모리
225280kshitij_sodani도서관 (JOI18_library)C++17
0 / 100
552 ms504 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){ if(ll==n-1 and aa[n-1]==2){ ll=-1; } else{ ll=l; } /* 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){ //ll=l; ll=l; } else{ ll=-1; // return -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 and i!=ind){ 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{ solve(ind,mid+1,r); } } } } 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; for(int i=0;i<n;i++){ int y=x; if(i==n-1 and st==0){ break; } ll=-2; solve(x,0,n-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[y]=0; } /*if(kk>1){ while(true){ continue; } }*/ 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(4); return 0; }*/
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...