Submission #1289809

#TimeUsernameProblemLanguageResultExecution timeMemory
1289809lambd47ICC (CEOI16_icc)C++20
90 / 100
71 ms620 KiB
#include<bits/stdc++.h> #include"icc.h" using namespace std; #define ll long long #define L(i,j,k) for(int i=(j);i<=(k);i++) #define R(i,j,k) for(int i=(j);i>=(k);i--) #define sz(v) ((int)(v).size()) #define all(v) (v).begin(),(v).end() /* int query(int a, int b, vector<int> va, vector<int> vb){ cout<<a<<" "<<b<<"\n"; for(auto x:va)cout<<x<<" "; cout<<"\n"; for(auto y:vb)cout<<y<<" "; cout<<"\n"; int x;cin>>x; return x; } void setRoad(int a,int b){ cout<<a<<" "<<b<<"receba\n"; }*/ const int MX=1e2+7; const int lg=7; void run(int n){ vector<vector<int>> vec(n); L(i,0,n-1)vec[i].push_back(i+1); int aa[MX]; int bb[MX]; auto ask=[&](vector<int> a, vector<int> b)->bool{ L(i,0,sz(a)-1)aa[i]=a[i]; L(i,0,sz(b)-1)bb[i]=b[i]; //cout<<"=========\n"; return query(sz(a),sz(b),aa,bb);//mudar essa bullshitaiada }; R(tam,n,2){ vector<vector<int>> v(2); L(i,0,lg-1){ L(j,0,tam-1){ int b=((1<<i)&j)?1:0; for(auto a:vec[j])v[b].push_back(a); } if(ask(v[0],v[1]))break; v[0].clear(); v[1].clear(); } int l=0;int r=sz(v[0])-1; int ans=0; vector<int> aux; while(l<=r){ aux.clear(); int m=(l+r)/2; if(l==r){ ans=l; l=r+1; continue; } L(i,l,m)aux.push_back(v[0][i]); if(ask(aux,v[1])){ r=m; } else{ l=m+1; } } vector<int> goat;goat.push_back({v[0][ans]}); l=0;r=sz(v[1])-1; ans=l; while(l<=r){ aux.clear(); int m=(l+r)/2; if(l==r){ ans=l; l=r+1; continue; } L(i,l,m)aux.push_back(v[1][i]); if(ask(aux,goat)){ r=m; } else{ l=m+1; } } int a=goat[0]; int b=v[1][ans]; setRoad(a,b); int ida;int idb; L(i,0,tam-1){ for(auto x:vec[i]){ if(x==a)ida=i; if(x==b)idb=i; } } for(auto x:vec[ida])vec[idb].push_back(x); swap(vec[tam-1],vec[ida]); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...