Submission #1055575

#TimeUsernameProblemLanguageResultExecution timeMemory
1055575vjudge1Prisoner Challenge (IOI22_prison)C++17
80 / 100
6 ms1116 KiB
#include "prison.h" #include <vector> using namespace std; int ithidk(int n,int ind){ while(ind--) n/=3; return n%3; } int pw[10]; int lstidk(int n,int ind){ return n % pw[ind]; } vector<int> which_to_do(int num,int n){ vector<int>res(n+1); res[0]=(num+2)/3&1; int BBit=8-(num+2)/3,vl=(num-1)%3; if(!num) for(int i=1;i<=n;i++) res[i]=ithidk(i,7)+1; else for(int i=1;i<=n;i++) { int c=ithidk(i,BBit); if(c<vl)res[i]=-res[0]-1; else if(c>vl)res[i]=-!res[0]-1; else { int K=lstidk(i,BBit); if(K==0) res[i]=-res[0]-1; else if(K==pw[BBit]-1) res[i]=-!res[0]-1; else res[i]=min(22,ithidk(i,BBit-1)+1+(num+2)/3*3); } } return res; } vector<int>finale(int n){ vector<int>res(n+1); for(int i=1;i<=n;i++) res[i]=(i%3?-2:-1); return res; } vector<vector<int>> devise_strategy(int N) { pw[0]=1; for(int i=1;i<10;i++) pw[i]=pw[i-1]*3; vector<vector<int>> ans; for(int i=0;i<22;i++) ans.push_back(which_to_do(i,N)); ans.push_back(finale(N)); return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...