제출 #980317

#제출 시각아이디문제언어결과실행 시간메모리
980317sleepntsheep죄수들의 도전 (IOI22_prison)C++17
53 / 100
13 ms1372 KiB
#include "prison.h" //#include<cstdio> #include <vector> std::vector<std::vector<int>> devise_strategy(int N) { constexpr int B = 2, X = 28; 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, 13); write(0, i, 1+13*2+d); } for(int read=1;read<=X;++read) { auto write_ = [&](int j,int x) { write(read,j,x); }; int at=(read-1)/B; int dd=(read-1)%B; int turn=((read-1)/2)%2 ? 'A':'B'; if(turn=='B') write_(0, 1); else write_(0, 0); for(int i=1;i<=N;++i) { int ee=get(i,at); int ff=at>0?get(i,at-1):-1; if(ee==dd) write_(i, 1+(at-1)*2+ff); else { if(turn == 'B') write_(i, ee>dd?-1:-2); else write_(i, ee>dd?-2:-1); } } } return s; /* // * compare digits-by-digits // * // * On base B, this happens ln(N)/ln(B) iterations // * each iterations need B place to store the result, // * and another to denotes that one need to check the next bits // * f(B) = (B + 1) * ln(N) / ln (B) constexpr int B = 3, X = 31; 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; }; for(int read=0;read<=X;++read) { auto write = [&](int j,int x) { s[read][j] = x; }; int at=(read)/(B+1); int dd=(read)%(B+1); if(dd>0) { write(0, 1); --dd; for(int i=1;i<=N;++i) { int ee=get(i,at); if(ee==dd) write(i, (at)*(B+1)); else write(i, ee>dd?-1:-2); } } else { write(0,0); for(int i=1;i<=N;++i) { int to = at ? at - 1 : 7; write(i, to*(B+1)+1+get(i,to)); } } } return s; */ }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...