This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "prison.h"
#include <vector>
std::vector<std::vector<int>> devise_strategy(int N) {
int X = 31;
std::vector<std::vector<int> > s(X, std::vector<int>(N+1));
auto get = [&](int x, int i)
{
while(i--) x/=3;
return x%3;
};
s[0][0] = 0;
for(int i=1;i<=N;++i)
s[0][i]=8*3 + get(i,8) + 1;
for(int read=1;read<=X;++read)
{
int at=(read-1)/3;
int dd=(read-1)%3;
s[read][0]=1;
if (at>0)
{
for(int i=1;i<=N;++i)
{
int ee=i&3;
if(ee==dd)
s[read][i]=(at-1)*3 + get(i,at-1) + 1;
else if (ee>dd)
s[read][i]=-1;
else
s[read][i]=-2;
}
}
else
{
for(int i=1;i<=N;++i)
{
int ee=i&3;
if(ee<dd)
s[read][i]=-2;
else if(ee>dd)
s[read][i]=-1;
else /* unreachable ? */
s[read][i]=-2;
}
}
}
return s;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |