Submission #819031

#TimeUsernameProblemLanguageResultExecution timeMemory
819031Faisal_SaqibCarnival (CEOI14_carnival)C++17
100 / 100
19 ms312 KiB
#include <iostream> #include <set> #include <map> #include <vector> using namespace std; int par[1000]; int get(int x) { if(par[x]==x) { return x; } return par[x]=get(par[x]); } void join(int a,int b) { a=get(a); b=get(b); if(a<b) { par[b]=a; } else { par[a]=b; } } bool match(vector<int> v,int y) { cout<<v.size()+1; for(auto i:v) { cout<<' '<<i; } cout<<' '<<y<<endl; cin>>y; if(y==v.size()) { return 1; } else{ return 0; } } // int solve(vector<int> H,int pe) // { // vector<int> fh,sh; // int mid=(H.size()+1)/2; // for(int i=0;i<H.size();i++) // { // if(i<mid) // { // fh.push_back(H[i]); // } // else // { // sh.pb(H[i]); // } // } // } int main() { int n; cin>>n; for(int i=1;i<=n;i++) { par[i]=i; } // solve(1,n); vector<int> hg={1}; for(int i=2;i<=n;i++) { if(match(hg,i)) { for(auto j:hg) { if(match({j},i)) { join(i,j); break; } } } else { hg.push_back(i); } } cout<<0; int val[n+4]; int cdx=1; for(int i=1;i<=n;i++) { if(get(i)==i) { val[i]=cdx++; } } for(int i=1;i<=n;i++) { cout<<' '<<val[get(i)]; } cout<<endl; return 0; }

Compilation message (stderr)

carnival.cpp: In function 'bool match(std::vector<int>, int)':
carnival.cpp:37:6: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   37 |  if(y==v.size())
      |     ~^~~~~~~~~~
#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...