제출 #920854

#제출 시각아이디문제언어결과실행 시간메모리
920854AkibAzmainPrisoner Challenge (IOI22_prison)C++17
65 / 100
10 ms1116 KiB
#include "prison.h"

#include <bits/stdc++.h>
using namespace std;

std::vector<std::vector<int>> devise_strategy (int n) {
  vector < vector < int > > ans (25, vector < int > (n + 1));
  vector < int > mp (25);
  for (int i = 0, j = 0; i < 25; ++i)
    {
      if (i == 1 || i == 3) continue;
      mp[i] = j++;
    }
  mp[1] = mp[3] = -1;
  for (int i = 0; i < 8; ++i)
     for (int j = 0; j < 3; ++j)
      {
        int k = mp[i * 3 + j + 1];
        if (k == -1) continue;
        ans[k][0] = i % 2;
        for (int m = 1; m <= n; ++m)
          {
            int p = m;
            for (int q = 0; q < i; ++q) p /= 3;
            p %= 3;
            if (p < j) ans[k][m] = -1 - (i % 2);
            else if (p > j) ans[k][m] = -2 + (i % 2);
            else
              {
                if (i == 0) continue;
                p = m;
                for (int q = 0; q < i - 1; ++q) p /= 3;
                p %= 3;
                if (i == 1 && p != 1)
                  {
                    if (p == 2) ans[k][m] = -2 + (i % 2);
                    else ans[k][m] = -1 - (i % 2);
                  }
                else ans[k][m] = mp[(i - 1) * 3 + p + 1];
              }
          }
      }
  ans[0][0] = 8 % 2;
  for (int m = 1; m <= n; ++m)
    {
      int p = m;
      for (int q = 0; q < 7; ++q) p /= 3;
      p %= 3;
      ans[0][m] = mp[7 * 3 + p + 1];
    }
  // ans.erase (ans.begin () + 3);
  // ans.erase (ans.begin () + 1);
  return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...