Submission #885116

#TimeUsernameProblemLanguageResultExecution timeMemory
885116fanwenSequence (APIO23_sequence)C++17
50 / 100
143 ms43344 KiB
#include <bits/stdc++.h> #define fi first #define se second using namespace std; const int MAX = 1e5 + 5; int A[MAX]; vector <int> pos[MAX], max_pref[MAX], min_pref[MAX], max_suff[MAX], min_suff[MAX]; struct node { int ma, mi, lazy; node(int ma = 0, int mi = 0) : ma(ma), mi(mi), lazy(0) {} } it[MAX << 2]; node merge(const node &a, const node &b) { return node(max(a.ma, b.ma), min(a.mi, b.mi)); } void build(int idx, int l, int r) { if(l == r) it[idx] = node(l, r); else { int mid = l + r >> 1; build(idx << 1, l, mid); build(idx << 1 | 1, mid + 1, r); it[idx] = merge(it[idx << 1], it[idx << 1 | 1]); } } void push(int idx) { if(!it[idx].lazy) return; it[idx << 1].ma += it[idx].lazy; it[idx << 1].mi += it[idx].lazy; it[idx << 1 | 1].ma += it[idx].lazy; it[idx << 1 | 1].mi += it[idx].lazy; it[idx << 1].lazy += it[idx].lazy; it[idx << 1 | 1].lazy += it[idx].lazy; it[idx].lazy = 0; } void update(int idx, int l, int r, int u, int v, int val) { if(l > v || r < u) return; if(l >= u && r <= v) { it[idx].ma += val; it[idx].mi += val; it[idx].lazy += val; return; } push(idx); int mid = l + r >> 1; update(idx << 1, l, mid, u, v, val); update(idx << 1 | 1, mid + 1, r, u, v, val); it[idx] = merge(it[idx << 1], it[idx << 1 | 1]); } node get(int idx, int l, int r, int u, int v) { if(l > v || r < u) return node(-1e9, 1e9); if(l >= u && r <= v) return it[idx]; push(idx); int mid = l + r >> 1; return merge(get(idx << 1, l, mid, u, v), get(idx << 1 | 1, mid + 1, r, u, v)); } int sequence(int n, vector <int> a) { for (int i = 0; i < n; ++i) A[i + 1] = a[i]; for (int i = 1; i <= n; ++i) pos[A[i]].push_back(i); // for (int i = 1; i <= n; ++i) cout << A[i] << " \n"[i == n]; build(1, 0, n); for (int i = 1; i <= n; ++i) { for (auto &j : pos[i]) { min_pref[i].push_back(get(1, 0, n, 0, j - 1).mi); max_suff[i].push_back(get(1, 0, n, j, n).ma); } for (auto &j : pos[i]) update(1, 0, n, j, n, -2); for (auto &j : pos[i]) { min_suff[i].push_back(get(1, 0, n, j, n).mi); max_pref[i].push_back(get(1, 0, n, 0, j - 1).ma); } } auto check = [&] (int res) -> bool { for (int i = 1; i <= n; ++i) { for (int j = 0; j + res - 1 < (int) pos[i].size(); ++j) { if(max_pref[i][j] >= min_suff[i][j + res - 1] && max_suff[i][j + res - 1] >= min_pref[i][j]) { return true; } } } return false; }; int l = -1, r = n + 1; while(r - l > 1) { int mid = l + r >> 1; if(check(mid)) l = mid; else r = mid; } return l; } #ifdef local signed main() { freopen("TASK.inp", "r", stdin); freopen("TASK.out", "w", stdout); int n; cin >> n; vector <int> a(n); for (int i = 0; i < n; ++i) cin >> a[i]; cout << sequence(n, a); } #endif // local

Compilation message (stderr)

sequence.cpp: In function 'void build(int, int, int)':
sequence.cpp:25:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   25 |     int mid = l + r >> 1;
      |               ~~^~~
sequence.cpp: In function 'void update(int, int, int, int, int, int)':
sequence.cpp:54:15: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   54 |   int mid = l + r >> 1;
      |             ~~^~~
sequence.cpp: In function 'node get(int, int, int, int, int)':
sequence.cpp:68:15: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   68 |   int mid = l + r >> 1;
      |             ~~^~~
sequence.cpp: In function 'int sequence(int, std::vector<int>)':
sequence.cpp:105:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
  105 |     int mid = l + r >> 1;
      |               ~~^~~
#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...