제출 #979474

#제출 시각아이디문제언어결과실행 시간메모리
97947412345678서열 (APIO23_sequence)C++17
0 / 100
2070 ms380612 KiB
#include "sequence.h" #include <bits/stdc++.h> using namespace std; const int nx=5e5+5; int n, a[nx], res, t; map<int, int> mp; struct persist { struct node { int f; node *l, *r; node(int f): f(f), l(0), r(0){} }; typedef node* pnode; pnode rt[nx]; void build(int l, int r, pnode &k) { k=new node(0); if (l==r) return; int md=(l+r)/2; build(l, md, k->l); build(md+1, r, k->r); } void update(int l, int r, pnode &k, pnode t, int idx) { k=new node(*t); if (l==r) return k->f++, void(); int md=(l+r)/2; if (idx<=md) update(l, md, k->l, t->l, idx); else update(md+1, r, k->r, t->r, idx); k->f=k->l->f+k->r->f; } int query(int l, int r, pnode k, pnode t, int key) { if (l==r) return k->f-t->f; int md=(l+r)/2; if (k->l->f-t->l->f>=key) return query(l, md, k->l, t->l, key); else return query(md+1, r, k->r, t->r, key-k->l->f-t->l->f); } } s; int sequence(int N, std::vector<int> A) { n=N; for (int i=1; i<=n; i++) a[i]=A[i-1], mp[a[i]]=0; for (auto &[x, y]:mp) y=++t; s.build(1, n, s.rt[0]); for (int i=1; i<=n; i++) a[i]=mp[a[i]], s.update(1, n, s.rt[i], s.rt[i-1], a[i]); for (int i=1; i<=n; i++) { for (int j=1; j<=i; j++) { if ((i-j+1)%2) res=max(res, s.query(1, n, s.rt[i], s.rt[j-1], ((i-j+2)/2))); else res=max({res, s.query(1, n, s.rt[i], s.rt[j-1], (i-j+1)/2), s.query(1, n, s.rt[i], s.rt[j-1], (i-j+1/2)+1)}); //cout<<"debug "<<i<<' '<<j<<' '<<res<<'\n'; } } //cout<<"debug "<<s.query(1, n, 1, s.rt[8], s.rt[0], 4)<<'\n'; //cout<<"debug "<<s.query(1, n, 1, s.rt[8], s.rt[0], 5)<<'\n'; return res; }
#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...