Submission #415759

#TimeUsernameProblemLanguageResultExecution timeMemory
415759KoDThe Collection Game (BOI21_swaps)C++17
25 / 100
176 ms1092 KiB
#include <bits/stdc++.h> #include "swaps.h" template <class T> using Vec = std::vector<T>; void solve(int N, int V) { if (V == 5000) { Vec<char> done(N); Vec<int> ans; while (true) { Vec<int> remain; for (int i = 0; i < N; ++i) { if (!done[i]) { remain.push_back(i); } } if (remain.empty()) { break; } while (remain.size() > 1) { Vec<int> next; Vec<std::array<int, 2>> ask; for (int i = 0; i + 1 < (int) remain.size(); i += 2) { schedule(remain[i] + 1, remain[i + 1] + 1); ask.push_back({remain[i + 1], remain[i]}); } const auto ret = visit(); for (int i = 0; i < (int) ret.size(); ++i) { next.push_back(ask[i][ret[i]]); } if (remain.size() % 2 == 1) { next.push_back(remain.back()); } remain = std::move(next); } done[remain[0]] = true; ans.push_back(remain[0] + 1); } answer(ans); } else { Vec<std::queue<int>> cur(N); for (int i = 0; i < N; ++i) { cur[i].push(i + 1); } while (cur.size() > 1) { Vec<std::queue<int>> next; if (cur.size() % 2 == 1) { next.push_back(cur.back()); cur.pop_back(); } const int size = (int) cur.size() / 2; while (true) { Vec<int> ask; for (int i = 0; i < size; ++i) { const int l = 2 * i; const int r = 2 * i + 1; if (cur[l].empty()) { std::swap(cur[l], cur[r]); } if (cur[r].empty()) { while (!cur[l].empty()) { next[i].push(cur[l].front()); cur[l].pop(); } } else { schedule(cur[l].front(), cur[r].front()); ask.emplace_back(i); } } if (ask.empty()) { break; } const auto ret = visit(); for (int i = 0; i < (int) ret.size(); ++i) { const auto k = ask[i]; const auto idx = 2 * k + 1 - ret[i]; next[k].push(cur[idx].front()); cur[idx].pop(); } } } Vec<int> ans; while (!cur[0].empty()) { ans.push_back(cur[0].front()); cur[0].pop(); } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...