Submission #1071045

#TimeUsernameProblemLanguageResultExecution timeMemory
1071045sleepntsheepAncient Machine (JOI21_ancient_machine)C++17
5 / 100
2101 ms10164 KiB
#include "Anna.h" #include <algorithm> #include <string> #include <vector> using namespace std; namespace { } void Anna(int N, std::vector<char> S) { int freq[3] {}, ord[3] {}; for (char c : S) ++freq[(int)(c - 'X')]; int o[3] = {0, 1, 2}; sort(o, o + 3, [&](int a, int b){ return freq[a] > freq[b]; }); int j = 0; for (auto x : o) { Send(x >> 1); Send(x & 1); ord[x] = j++; } for (int i = 0; i < N; ++i) { int v = S[i] - 'X'; switch (ord[v]) { case 0: Send(0); break; case 1: Send(1); Send(0); break; case 2: Send(1); Send(1); break; } } }
#include "Bruno.h" #include <set> #include <vector> #include <algorithm> using namespace std; namespace { vector<int> decode(int N, vector<int> A) { int m1, m2, m3; vector<int> v; m1 = A[0] * 2 + A[1], m2 = A[2] * 2 + A[3], m3 = A[4] * 2 + A[5]; for (int i = 6; i < (int)A.size(); ) if (A[i] == 0) v.push_back(m1), ++i; else v.push_back((A[i + 1]) ? m3 : m2), ++i, ++i; return v; } } // namespace void Bruno(int N, int L, std::vector<int> A) { auto v = decode(N, A); vector<int> ded(N); vector<set<int> > oc(3); for (int i = 0; i < N; ++i) oc[v[i]].insert(i); if (oc[0].empty() or oc[2].empty() or *oc[0].begin() > *oc[2].rbegin()) { for (int i = 0; i < N; ++i) Remove(i); return; } int x0 = *oc[0].begin(); int z0 = *oc[2].rbegin(); auto REmove = [&](int i) { if (ded[i]) return; ded[i] = 1; oc[v[i]].erase(i); Remove(i); }; int at = x0; for (; at < z0 ;) { auto zi = oc[2].upper_bound(at); while (1) { auto yi = oc[1].lower_bound(*zi); if (yi == oc[1].begin() or *--yi < x0) break; auto xi = prev(oc[0].lower_bound(*yi)); for (int i = *xi + 1; i < *yi; ++i) REmove(i); for (int i = *yi + 1; i < *zi; ++i) REmove(i); REmove(*yi); if (*xi != x0) REmove(*xi); } for (int i = *zi - 1; i > at; --i) REmove(i); at = *zi; } for (int i = 0; i < N; ++i) REmove(i); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...