Submission #1124190

#TimeUsernameProblemLanguageResultExecution timeMemory
1124190epicci23Rarest Insects (IOI22_insects)C++17
25 / 100
138 ms436 KiB
#include "insects.h"
#include "bits/stdc++.h"
using namespace std;

vector<int> v,Left;
int D;

void Clear(){
  while(!v.empty()){
    move_outside(v.back());
    v.pop_back();
  }
}

int min_cardinality(int n){
  for(int i=0;i<n;i++){
    v.push_back(i);
    move_inside(i);
    int u = press_button();
    if(u == 1) continue;
    move_outside(i);
    v.pop_back();
  }

  D = v.size();
  for(int i=0;i<n;i++) Left.push_back(i);

  if(D > n / 2) return 1;
  if(D == 1) return n;
  int _n = n;
  while(_n > D){
    int B = _n / D;
    Clear();
    for(int i=0;i<Left.size();i++){
      v.push_back(Left[i]);
      move_inside(Left[i]);
      int u = press_button();
      if(u > B){
        move_outside(Left[i]);
        v.pop_back();
      }
    }
    if(v.size() == B * D) return B;
    _n = v.size();
    Left = v;
  }

  return 1;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...