Submission #726345

#TimeUsernameProblemLanguageResultExecution timeMemory
726345ismayilRarest Insects (IOI22_insects)C++17
50.03 / 100
205 ms548 KiB
#pragma GCC optimize("O3") #include "insects.h" #include <bits/stdc++.h> using namespace std; //g++ -std=c++17 insects.cpp stub.cpp int D, N; const int MAX = 3000; int is_in[MAX]; multiset<int> in; bool check(int m){ vector<int> new_in; for(int j = 0; j < N; j++){ if(is_in[j]) continue; move_inside(j); if(press_button() > m){ move_outside(j); }else{ in.insert(j); is_in[j] = 1; new_in.push_back(j); } } bool flag = false; if(in.size() < m * D){ flag = true; for(auto i : new_in) move_outside(i), in.erase(i), is_in[i] = 0; } return flag; } int min_cardinality(int n) { N = n; for(int j = 0; j < N; j++){ move_inside(j); if(press_button() > 1){ move_outside(j); }else{ in.insert(j); is_in[j] = 1; } } D = in.size(); int l = 1, r = N / D; while(l <= r){ int m = (l + r) / 2; if(check(m)) r = m - 1; else l = m + 1; } return r; }

Compilation message (stderr)

insects.cpp: In function 'bool check(int)':
insects.cpp:24:15: warning: comparison of integer expressions of different signedness: 'std::multiset<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   24 |  if(in.size() < m * D){
      |     ~~~~~~~~~~^~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...