Submission #512392

#TimeUsernameProblemLanguageResultExecution timeMemory
512392KaguyaPo (COCI21_po)C++17
60 / 70
1080 ms12804 KiB
#include <bits/stdc++.h> using namespace std; #pragma GCC optimize("O3","unroll-loops", "Ofast") #pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt") set<int> pos[100051]; int main() { ios::sync_with_stdio(false); cin.tie(0); // freopen("input.txt", "r", stdin); int n; cin >> n; vector<int> a(n); bool have = false; for (auto& t : a) { cin >> t; if (t == 0) have = true; } vector<int> ve; for (int i = 0; i < n; i++) ve.push_back(a[i]); sort(ve.begin(), ve.end()); ve.resize(unique(ve.begin(), ve.end()) - ve.begin()); for (int i = 0; i < n; i++) { a[i] = lower_bound(ve.begin(), ve.end(), a[i]) - ve.begin(); } int ans = 0; vector<int> se; vector<bool> vis(n + 25, false); vector<bool> was(n + 25, false); for (int i = 0; i < n; i++) if (!was[a[i]]) { se.push_back(a[i]); was[a[i]] = true; } sort(se.rbegin(), se.rend()); for (int i = 0; i < n; i++) pos[a[i]].insert(i); if (!have) { ans += 1; se.pop_back(); } if (have && se.back() == 0) se.pop_back(); while (!se.empty()) { int x = se.back(); se.pop_back(); for (auto t : pos[x]) { if (vis[t]) continue; vis[t] = true; int i = t; ans += 1; priority_queue<pair<int, int>, vector<pair<int, int>> > vs; while (i < n && a[i] >= x) { if (a[i] > x) vs.push({a[i], i}); if (!vs.empty() && ((vs.top())).first < x) { while (!vs.empty() && ((vs.top())).first < x) { pos[(vs.top()).first].erase(vs.top().second); ans += 1; vs.pop(); } } if (a[i] == x) vis[i] = true; i++; } if (a[i] == x) vis[i] = true; } } cout << ans << '\n'; }
#Verdict Execution timeMemoryGrader output
Fetching results...