Submission #951341

#TimeUsernameProblemLanguageResultExecution timeMemory
951341GrandTiger1729Toxic Gene (NOI23_toxic)C++17
97.30 / 100
43 ms604 KiB
#include "toxic.h" #include <bits/stdc++.h> using namespace std; const int K = 8, T = 30; vector<int> encode(vector<int> qry) { int n = qry.size(); vector<int> ret; for (int i = 0; i < n; i++) { for (int j = 0; j < (1 << i); j++) { ret.push_back(qry[i]); } } return ret; } void determine_type(int n) { vector<int> ord(n); iota(ord.begin(), ord.end(), 1); string ans(n + 1, 'R'); int cnt = 0; int tt = -1; vector<int> stk; int i = 0; while (cnt < T && i < n) { shuffle(ord.begin() + i, ord.end(), mt19937(time(0) + 777771449)); int j = min(n, i + K); int xx = -1; { vector<int> qry; for (int k = i; k < j; k++) { qry.push_back(ord[k]); } int x = min(stk.size(), K - qry.size()); for (int k = 0; k < x; k++) { qry.push_back(stk.end()[-1 - k]); } xx = query_sample(encode(qry)); if (xx == (1 << qry.size()) - 1) { stk.insert(stk.end(), qry.begin(), qry.end()); i = j; continue; } else { for (int k = j - i; k < qry.size(); k++) { ans[qry[k]] = (xx >> k & 1) ? 'S' : 'R'; } for (int k = 0; k < x; k++) { stk.pop_back(); } } } int l = i, r = j; while (l < r && xx >> (l - i) & 1) { l++; } while (r > l && xx >> (r - 1 - i) & 1) { r--; } auto make_query = [&](int mid) { vector<int> qry; for (int k = l; k < mid; k++) { qry.push_back(ord[k]); } int x = min(stk.size(), K - qry.size()); for (int k = 0; k < x; k++) { qry.push_back(stk.end()[-1 - k]); } return qry; }; while (l < r - 1) { int mid = (l + r) / 2; vector<int> qry = make_query(mid); int res = query_sample(encode(qry)); if (res == (1 << qry.size()) - 1) { l = mid; } else { int x = qry.size() - (mid - l); for (int k = mid - l; k < qry.size(); k++) { ans[qry[k]] = (res >> k & 1) ? 'S' : 'R'; } for (int k = 0; k < x; k++) { stk.pop_back(); } r = mid; } } for (int k = 0; k < l - i; k++) { ans[ord[i + k]] = (xx >> k & 1) ? 'S' : 'R'; } ans[ord[l]] = 'T'; i = l + 1; tt = ord[l]; cnt++; } while (i < n) { stk.push_back(ord[i++]); } while (stk.size()) { int x = min((int)stk.size(), K); vector<int> qry; for (int k = 0; k < x; k++) { qry.push_back(stk.back()); stk.pop_back(); } auto tmp = encode(qry); tmp.push_back(tt); int res = query_sample(tmp); for (int k = 0; k < (int)qry.size(); k++) { ans[qry[k]] = (res >> k & 1) ? 'S' : 'R'; } } for (int j = 1; j <= n; j++) { answer_type(j, ans[j]); } }

Compilation message (stderr)

toxic.cpp: In function 'void determine_type(int)':
toxic.cpp:53:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   53 |     for (int k = j - i; k < qry.size(); k++)
      |                         ~~^~~~~~~~~~~~
toxic.cpp:98:29: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   98 |     for (int k = mid - l; k < qry.size(); k++)
      |                           ~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...