Submission #631234

#TimeUsernameProblemLanguageResultExecution timeMemory
631234fuad27Rarest Insects (IOI22_insects)C++17
0 / 100
18 ms280 KiB
#include "insects.h" #include <bits/stdc++.h> using namespace std; int min_cardinality(int N) { vector<int> idx_type; idx_type.push_back(0); move_inside(0); for(int i = 1;i<N;i++) { move_inside(i); int val=press_button(); if(val == 2)move_outside(i); else idx_type.push_back(i); } for(int i:idx_type) { //~ cout << i << endl; move_outside(i); } vector<int> l(N, -1), r(N, idx_type.size()-1); for(int i = 0;i<idx_type.size();i++) { r[idx_type[i]]=i; l[idx_type[i]]=i-1; } for(int i = 0;i<N;i++) { if(l[i]!=i-1)r[i]=i-1; } vector<pair<int,int>> que; int tmp=0; while(1) { que.clear(); bool check=false; for(int i = 0;i<N;i++) { if(r[i]-l[i]<=1)continue; que.push_back({(r[i]+l[i])/2, i}); check=true; } int cnt=tmp; sort(que.begin(), que.end()); for(int i = 0;i<que.size();i++) { int mid = que[i].first; while(cnt > mid+1) { move_outside(idx_type[--cnt]); } while(cnt <= mid) { move_inside(idx_type[cnt++]); } move_inside(que[i].second); int val=press_button(); //~ assert(val!=3); if(val == 2) { r[que[i].second]=que[i].first; //~ cout << que[i].second << " " << mid << " " << val << endl; } else { l[que[i].second]=que[i].first; //~ cout << que[i].second << " " << mid << " " << val << endl; } move_outside(que[i].second); } tmp=cnt; if(!check)break; } vector<int> cnt(N+1, 0); for(int i = 0;i<N;i++) { //~ cout << idx_type[r[i]] << " "; cnt[idx_type[r[i]]]++; } //~ cout << endl; int ans=20000; for(int i = 0;i<N;i++) { if(cnt[i]==0)continue; ans=min(ans, cnt[i]); } return ans; }

Compilation message (stderr)

insects.cpp: In function 'int min_cardinality(int)':
insects.cpp:19:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   19 |  for(int i = 0;i<idx_type.size();i++) {
      |                ~^~~~~~~~~~~~~~~~
insects.cpp:38:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |   for(int i = 0;i<que.size();i++) {
      |                 ~^~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...