# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
55987 | 2018-07-09T09:15:54 Z | imeimi2000 | Sushi (JOI16_sushi) | C++17 | 12000 ms | 67820 KB |
#include <iostream> #include <algorithm> #include <vector> #include <queue> #include <deque> #include <set> #include <map> #include <unordered_map> #include <functional> #include <cstring> #include <cmath> #include <ctime> #include <cstdlib> using namespace std; typedef long long llong; typedef long double ld; typedef pair<int, int> pii; typedef pair<llong, llong> pll; const int t = 700; struct pq { vector<int> x; pq() {} void push(int v) { x.push_back(v); for (int i = x.size() - 1; i > 0; ) { int p = (i - 1) >> 1; if (x[p] < x[i]) swap(x[p], x[i]); i = p; } } int top() const { return x[0]; } bool empty() const { return x.empty(); } void pop() { swap(x[0], x.back()); x.pop_back(); int i = 0; while (1) { int l = i << 1 | 1; if (x.size() <= l) break; int r = l + 1; if (x.size() <= r || x[r] < x[l]) { if (x[i] < x[l]) swap(x[i], x[l]); else break; i = l; } else { if (x[i] < x[r]) swap(x[i], x[r]); else break; i = r; } } } void clear() { x.clear(); } void init(int arr[], int n) { x.resize(n, 0); for (int i = 0; i < n; ++i) { x[i] = arr[i]; } for (int i = n; i--; ) { int p = (i - 1) >> 1; if (x[i] < x[p]) continue; int j = i; while (1) { int l = i << 1 | 1; if (x.size() <= l) break; int r = l + 1; if (x.size() <= r || x[r] < x[l]) { if (x[i] < x[l]) swap(x[i], x[l]); else break; i = l; } else { if (x[i] < x[r]) swap(x[i], x[r]); else break; i = r; } } } } }; int n, q, g; int v[400000]; pq mx[t]; pq pass[t]; void reconstruct(int x) { for (int i = x * t; i < (x + 1) * t && i < n; ++i) { pass[x].push(-v[i]); v[i] = -pass[x].top(); pass[x].pop(); } pass[x].clear(); } void construct(int x) { mx[x].init(v + x * t, max(min(t, n - x * t), 0)); } int main() { scanf("%d%d", &n, &q); for (int i = 0; i < n; ++i) { scanf("%d", v + i); } g = (n - 1) / t + 1; for (int i = 0; i < t; ++i) { construct(i); } while (q--) { int s, e, p; scanf("%d%d%d", &s, &e, &p); --s; --e; int sg = s / t; int eg = e / t; reconstruct(sg); if (sg != eg) reconstruct(eg); if (sg == eg && s <= e) { for (int i = s; i <= e; ++i) { if (p < v[i]) swap(p, v[i]); } } else { for (int i = s; i < (sg + 1) * t && i < n; ++i) { if (p < v[i]) swap(p, v[i]); } for (int i = (sg + 1) % g; i != eg; i = (i + 1) % g) { pass[i].push(-p); mx[i].push(p); p = mx[i].top(); mx[i].pop(); } for (int i = eg * t; i <= e; ++i) { if (p < v[i]) swap(p, v[i]); } } construct(sg); if (sg != eg) construct(eg); printf("%d\n", p); } return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 240 ms | 376 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Execution timed out | 12069 ms | 67820 KB | Time limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 240 ms | 376 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |