Submission #980333

#TimeUsernameProblemLanguageResultExecution timeMemory
980333sleepntsheepPrisoner Challenge (IOI22_prison)C++17
80 / 100
12 ms1192 KiB
#include "prison.h" #include <vector> std::vector<std::vector<int>> devise_strategy(int N) { constexpr int B = 3, X = 22; std::vector<std::vector<int> > s(X+1, std::vector<int>(N+1)); auto get = [&](int x, int i) { while(i--) x/=B; return x%B; }; auto write = [&](int at,int j,int x) { s[at][j] = x; }; write(0, 0, 0); for(int i=1;i<=N;++i) { int d=get(i, 7); write(0, i, 1+7*B+d -2); } for(int read=1;read<=X;++read) { auto write_ = [&](int j,int x) { write(read,j,x); }; int at=(read-1 +2)/B; int dd=(read-1 +2)%B; int turn=at%2==1 ? 'B':'A'; if(read==1)dd=1; if(turn=='B') write_(0, 1); else write_(0, 0); for(int i=1;i<=N;++i) { int ee=get(i,at); if (at==0) { if(ee==2) { write_(i, turn == 'B' ? -1 : -2); } else if(ee==0) { write_(i, turn == 'B' ? -2 : -1); } else { write_(i, 1); } } else { int ff=get(i,at-1); if(ee==dd) { if(at-1==0) { if(ff==2) write_(i, turn == 'B' ? -1 : -2); else if(ff==0) write_(i, turn == 'B' ? -2 : -1); else write_(i, 1); } else { write_(i, 1+(at-1)*B+ff -2); } } else { if(turn == 'B') write_(i, ee>dd?-1:-2); else write_(i, ee>dd?-2:-1); } } } } return s; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...