QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#35366 | #964. Excluded Min | Froggygua | WA | 11ms | 55648kb | C++17 | 3.7kb | 2022-06-15 16:34:46 | 2022-06-15 16:34:48 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define N 500050
typedef long long ll;
const int inf=0x3f3f3f3f;
typedef pair<int,int> pii;
const pii Min=make_pair(-inf,0);
int n,m,a[N],ans[N];
struct Query{
int id,l,r;
}q[N];
class BIT{
int b[N];
inline int lowbit(int x){return x&(-x);}
public:
void Add(int x,int d){
while(x<=n)b[x]+=d,x+=lowbit(x);
}
int Ask(int x){
int ans=0;
while(x)ans+=b[x],x-=lowbit(x);
return ans;
}
int Query(int l,int r){
if(l>r)return 0;
return Ask(r)-Ask(l-1);
}
}B;
class Segment_Tree_2{
int Len;
struct node{
pii mx;
int add;
node(){mx=Min;}
inline void Add(int d){
mx.first+=d;
add+=d;
}
}t[N<<2];
#define ls u<<1
#define rs u<<1|1
inline void update(int u){
t[u].mx=max(t[ls].mx,t[rs].mx);
}
inline void pushdown(int u){
if(t[u].add){
t[ls].Add(t[u].add);
t[rs].Add(t[u].add);
t[u].add=0;
}
}
void _ins(int u,int L,int R,int x,pii d){
if(L==R){
t[u].mx=d;
return;
}
pushdown(u);
int mid=(L+R)>>1;
x<=mid?_ins(ls,L,mid,x,d):_ins(rs,mid+1,R,x,d);
update(u);
}
void _add(int u,int L,int R,int l,int r,int d){
if(L>=l&&R<=r){
t[u].Add(d);
return;
}
pushdown(u);
int mid=(L+R)>>1;
if(l<=mid)_add(ls,L,mid,l,r,d);
if(r>mid)_add(rs,mid+1,R,l,r,d);
update(u);
}
public:
void init(int _n){
Len=_n;
}
void Ins(int p,pii d){
_ins(1,1,Len,p,d);
}
pii get_max(){
return t[1].mx;
}
void Plus(int l,int r,int d){
if(l>r)return;
_add(1,1,Len,l,r,d);
}
}T;
class Segment_Tree_1{
int Len;
struct node{
pii mx;
node(){mx=Min;}
}t[N<<2];
inline void update(int u){
t[u].mx=max(t[ls].mx,t[rs].mx);
}
void _ins(int u,int L,int R,int x,pii d){
if(L==R){
t[u].mx=d;
return;
}
int mid=(L+R)>>1;
x<=mid?_ins(ls,L,mid,x,d):_ins(rs,mid+1,R,x,d);
update(u);
}
pii _ask(int u,int L,int R,int l,int r){
if(L>=l&&R<=r){
return t[u].mx;
}
int mid=(L+R)>>1;
pii ans=Min;
if(l<=mid)ans=max(ans,_ask(ls,L,mid,l,r));
if(r>mid)ans=max(ans,_ask(rs,mid+1,R,l,r));
return ans;
}
public:
void init(int _n){
Len=_n;
}
void Ins(int p,pii d){
_ins(1,1,Len,p,d);
}
pii Ask(int l,int r){
return _ask(1,1,Len,l,r);
}
}H;
set<pii> Sl,Sr;
void Insert(int u){
Sl.emplace(q[u].l,u);
Sr.emplace(q[u].r,u);
T.Ins(u,pii(B.Query(q[u].l,q[u].r),u));
}
void Delete(int u){
auto it=Sl.erase(Sl.find(pii(q[u].l,u)));
int R=it==Sl.end()?m:it->second;
it=Sr.erase(Sr.find(pii(q[u].r,u)));
int lim=it==Sr.begin()?0:(--it)->first;
while(true){
auto [r,v]=H.Ask(u,R);
v=-v;
if(r<=lim)break;
H.Ins(v,Min);
Insert(v);
}
T.Ins(u,Min);
}
vector<int> p[N];
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n>>m;
for(int i=1;i<=n;++i){
cin>>a[i];
p[a[i]].push_back(i);
B.Add(i,1);
}
for(int i=1;i<=m;++i){
cin>>q[i].l>>q[i].r;
q[i].id=i;
}
sort(q+1,q+m+1,[&](Query a,Query b){
return a.l==b.l?(a.r==b.r?a.id<b.id:a.r>b.r):a.l<b.l;
});
H.init(m);
T.init(m);
for(int i=1,ri=-1;i<=m;++i){
if(q[i].r>ri){
Insert(i);
ri=q[i].r;
}
else{
H.Ins(i,pii(q[i].r,-i));
}
}
for(int i=500001;i>=0;--i){
for(auto x:p[i]){
B.Add(x,-1);
if(!Sl.empty()){
auto itl=Sr.lower_bound(pii(x,0));
auto itr=Sl.lower_bound(pii(x,inf));
if(itl!=Sr.end()&&itr!=Sl.begin()){
int l=itl->second,r=(--itr)->second;
T.Plus(l,r,-1);
}
}
}
while(true){
auto [sum,u]=T.get_max();
if(sum>=i){
ans[q[u].id]=i;
Delete(u);
}
else{
break;
}
}
}
for(int i=1;i<=m;++i){
cout<<ans[i]<<'\n';
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 6ms
memory: 55548kb
input:
3 3 0 0 2 1 3 2 3 3 3
output:
3 1 0
result:
ok 3 number(s): "3 1 0"
Test #2:
score: 0
Accepted
time: 2ms
memory: 55648kb
input:
3 2 1 2 2 1 2 1 3
output:
0 3
result:
ok 2 number(s): "0 3"
Test #3:
score: -100
Wrong Answer
time: 11ms
memory: 55040kb
input:
10 10 3 0 3 3 9 7 9 6 0 7 3 3 9 9 4 6 1 9 3 4 2 4 7 10 3 7 5 7 2 7
output:
0 1 0 5 1 2 1 1 0 3
result:
wrong answer 5th numbers differ - expected: '0', found: '1'