Submission #601981

#TimeUsernameProblemLanguageResultExecution timeMemory
601981FatihSolakCounting Mushrooms (IOI20_mushrooms)C++17
75.33 / 100
8 ms312 KiB
#include "mushrooms.h" #include <bits/stdc++.h> #define N 20000 using namespace std; int count_mushrooms(int n){ vector<int> a,b; a.push_back(0); int point = 1; int cur = 0; while( (n-point + max(a.size(),b.size()) - 1) / max(a.size(),b.size()) + cur > 300 ){ if(max(a.size(),b.size()) == 1){ if(use_machine({0,point})){ b.push_back(point); } else a.push_back(point); point++; } else{ if(a.size() > b.size()){ vector<int> ask; ask.push_back(a[0]); ask.push_back(point++); ask.push_back(a[1]); ask.push_back(point++); int val = use_machine(ask); if(val < 2){ a.push_back(ask[1]); } else{ b.push_back(ask[1]); } if(val % 2 == 0){ a.push_back(ask[3]); } else{ b.push_back(ask[3]); } } else{ vector<int> ask; ask.push_back(b[0]); ask.push_back(point++); ask.push_back(b[1]); ask.push_back(point++); int val = use_machine(ask); if(val < 2){ b.push_back(ask[1]); } else{ a.push_back(ask[1]); } if(val % 2 == 0){ b.push_back(ask[3]); } else{ a.push_back(ask[3]); } } } cur++; } int ret = 0; int asz = a.size(); int bsz = b.size(); if(asz > bsz){ for(int i = point;i<n;i+=asz){ vector<int> nums; int cnt = 0; for(int j = i;j<min(n,i + asz);j++){ nums.push_back(a[cnt++]); nums.push_back(j); } int sz = nums.size()/2; ret += sz - (use_machine(nums) + 1)/2; } } else{ for(int i = point;i<n;i+=bsz){ vector<int> nums; int cnt = 0; for(int j = i;j<min(n,i + bsz);j++){ nums.push_back(b[cnt++]); nums.push_back(j); } int sz = nums.size()/2; ret += (use_machine(nums) + 1)/2; } } return ret + asz; }

Compilation message (stderr)

mushrooms.cpp: In function 'int count_mushrooms(int)':
mushrooms.cpp:86:8: warning: unused variable 'sz' [-Wunused-variable]
   86 |    int sz = nums.size()/2;
      |        ^~
#Verdict Execution timeMemoryGrader output
Fetching results...