Submission #363028

#TimeUsernameProblemLanguageResultExecution timeMemory
3630282qbingxuanLast supper (IOI12_supper)C++14
0 / 100
353 ms22612 KiB
#include "advisor.h" #include <bits/stdc++.h> using namespace std; void ComputeAdvice(int *C, int N, int K, int M) { const int LG = 13; for (int i = 0; i < N; i++) { for (int j = 0; j < LG; j++) { WriteAdvice(C[i] >> j & 1); } } // cerr << "C = "; // for (int i = 0; i < N; i++) // cerr << C[i] << ' '; // cerr << '\n'; }
#include "assistant.h" #include <bits/stdc++.h> using namespace std; const int maxn = 100025; int C[maxn]; vector<int> last[maxn]; int scaffold[maxn]; bool onScaffold[maxn]; void Assist(unsigned char *A, int N, int K, int R) { const int LG = 13; for (int i = 0; i < N; i++) { for (int j = 0; j < LG; j++) { C[i] |= A[i*LG + j] * (1<<j); } } // cerr << "C = "; // for (int i = 0; i < N; i++) // cerr << C[i] << ' '; // cerr << '\n'; auto getLast = [](int i) { return last[i].empty() ? maxn : last[i].back(); }; for (int i = N-1; i >= 0; i--) last[C[i]].push_back(i); set<pair<int,int>, greater<>> st; // last, j for (int i = 0; i < K; i++) { scaffold[i] = i; onScaffold[i] = true; st.insert({ getLast(i), i }); } for (int i = 0; i < N; i++) { int req = GetRequest(); if (!onScaffold[req]) { // int pos = st.begin() -> second; // st.erase(st.begin()); last[req].pop_back(); int pos = -1; for (int j = 0; j < K; j++) if(pos == -1 || getLast(scaffold[pos]) < getLast(scaffold[j])) pos = j; PutBack(scaffold[pos]); onScaffold[scaffold[pos]] = false; onScaffold[req] = true; scaffold[pos] = req; // st.insert({ getLast(scaffold[pos]), pos }); } } }
#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...