BZOJ 1208 [HNOI2004] 애완동물 입양소 트랩
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define N 80010
#define mod 1000000
#define INF 0x7fffffff
using namespace std;
int n,size;
int ans;
int root;
struct node
{
int l,r,val,siz,rnd;
}tr[N];
void pushup(int rt)
{
tr[rt].siz=tr[tr[rt].l].siz+tr[tr[rt].r].siz+1;
}
void lturn(int &rt)
{
int t=tr[rt].r;
tr[rt].r=tr[t].l;
tr[t].l=rt;
tr[t].siz=tr[rt].siz;
pushup(rt);
rt=t;
}
void rturn(int &rt)
{
int t=tr[rt].l;
tr[rt].l=tr[t].r;
tr[t].r=rt;
tr[t].siz=tr[rt].siz;
pushup(rt);
rt=t;
}
void insert(int &rt,int v)
{
if(!rt)
{
rt=++size;
tr[rt].l=tr[rt].r=0;
tr[rt].siz=1,tr[rt].rnd=rand();
tr[rt].val=v;
return;
}
tr[rt].siz++;
if(v<=tr[rt].val)
{
insert(tr[rt].l,v);
if(tr[tr[rt].l].rnd<tr[rt].rnd)rturn(rt);
}else
{
insert(tr[rt].r,v);
if(tr[tr[rt].r].rnd<tr[rt].rnd)lturn(rt);
}
}
void del(int &rt,int v)
{
tr[rt].siz--;
if(tr[rt].val==v)
{
if(tr[rt].l==0||tr[rt].r==0){rt=tr[rt].l+tr[rt].r;return;}
if(tr[tr[rt].l].rnd<tr[tr[rt].r].rnd)
rturn(rt),del(rt,v);
else lturn(rt),del(rt,v);
}else if(v<tr[rt].val)del(tr[rt].l,v);
else del(tr[rt].r,v);
}
int ask_pre(int rt,int v)
{
if(!rt)return 0;
if(v<=tr[rt].val)
return ask_pre(tr[rt].l,v);
else
{
int ret=ask_pre(tr[rt].r,v);
return max(tr[rt].val,ret);
}
}
int ask_sub(int rt,int v)
{
if(!rt)return INF;
if(v>=tr[rt].val)
return ask_sub(tr[rt].r,v);
else
{
int ret=ask_sub(tr[rt].l,v);
return min(tr[rt].val,ret);
}
}
int main()
{
scanf("%d",&n);
int cnt=0;
for(int i=1;i<=n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
if(!cnt)
{
if(x)cnt--,insert(root,y);
else cnt++,insert(root,y);
}else if(cnt>0)
{
if(x)
{
cnt--;
int tmp1=ask_pre(root,y),tmp2=ask_sub(root,y);
if(!tmp1){ans=(ans+abs(tmp2-y))%mod,del(root,tmp2);continue;}
if(tmp2==INF){ans=(ans+abs(tmp1-y))%mod,del(root,tmp1);continue;}
if(y-tmp1<=tmp2-y)
{
ans=(ans+abs(y-tmp1))%mod;
del(root,tmp1);
}else
{
ans=(ans+abs(tmp2-y))%mod;
del(root,tmp2);
}
}else cnt++,insert(root,y);
}else
{
if(x)cnt--,insert(root,y);
else
{
cnt++;
int tmp1=ask_pre(root,y),tmp2=ask_sub(root,y);
if(!tmp1){ans=(ans+abs(tmp2-y))%mod,del(root,tmp2);continue;}
if(tmp2==INF){ans=(ans+abs(tmp1-y))%mod,del(root,tmp1);continue;}
if(y-tmp1<=tmp2-y)
{
ans=(ans+abs(y-tmp1))%mod;
del(root,tmp1);
}else
{
ans=(ans+abs(tmp2-y))%mod;
del(root,tmp2);
}
}
}
}
printf("%d
",ans);
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
vue 단일 페이지에 여러 개의 echarts 도표가 있을 때의 공용 코드 쓰기html에서: 데이터 처리는 말할 필요가 없다.응, 직접 그림을 그려: 공통 섹션: 이 페이지를 떠날 때 파괴: 추가 정보: Vue + Echarts 차트 표시 및 동적 렌더링 준비 작업 echarts 의존 설치 n...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.