Submission #977576

#TimeUsernameProblemLanguageResultExecution timeMemory
977576CSQ31Toxic Gene (NOI23_toxic)C++17
36.68 / 100
9 ms544 KiB
#include "toxic.h" #include<bits/stdc++.h> using namespace std; vector<int>tox; #define sz(a) (int)(a.size()) void find_toxic(vector<int>v){ //for(int x:v)cout<<x<<" "; //cout<<'\n'; if(sz(v) == 1){ //cout<<v[0]<<'\n'; answer_type(v[0],'T'); tox.push_back(v[0]); return; } int m = sz(v)/2; vector<int>a,b; for(int i=0;i<m;i++)a.push_back(v[i]); for(int i=m;i<sz(v);i++)b.push_back(v[i]); int res = query_sample(a); if(res == sz(a)){ for(int x:a)answer_type(x,'R');} else find_toxic(a); res = query_sample(b); if(res == sz(b)){ for(int x:b)answer_type(x,'R');} else find_toxic(b); } void determine_type(int n){ tox.clear(); vector<int>notoxic; for(int i=1;i<=n;i+=8){ vector<int>v; for(int j=0;j<8;j++){ if(i+j > n)break; for(int k=0;k<(1<<j);k++)v.push_back(i+j); } //for(int x:v)cout<<x<<" "; //cout<<'\n'; int res = query_sample(v); //cout<<res<<'\n'; if(res == sz(v)){ for(int j=0;j<8;j++){ if(i+j > n)break; notoxic.push_back(i+j); } }else{ vector<int>u; for(int j=0;j<8;j++){ if(i+j > n)break; if(res & (1<<j))answer_type(i+j,'S'); else u.push_back(i+j); } // for(int x:u)cout<<x<<" "; //cout<<'\n'; find_toxic(u); //cout<<"TES"<<'\n'; } } //for(int x:tox)cout<<x<<" "; //cout<<'\n'; //for(int x:notoxic)cout<<x<<" "; //cout<<'\n'; for(int i=0;i<sz(notoxic);i+=8){ vector<int>v; for(int j=0;j<8;j++){ if(i+j >= sz(notoxic))break; for(int k=0;k<(1<<j);k++)v.push_back(notoxic[i+j]); } v.push_back(tox[0]); int res = query_sample(v); for(int j=0;j<8;j++){ if(i+j >= sz(notoxic))break; if(res & (1<<j))answer_type(notoxic[i+j],'S'); else answer_type(notoxic[i+j],'R'); } } }
#Verdict Execution timeMemoryGrader output
Fetching results...