切傻逼题还能wa那么多次我也是醉了

好啦其实是sbt都不会敲了(一直用神器treap)

重点是研究了下陈大神的删除,以前treap的删除都是直接旋转去删的……

还是treap大法好&……

题解还用写么?就是找前驱找后继然后判断一下

const
maxn=;
mm=<<;
mmm=; var
left,right,value,s:array[..maxn]of longint;
ans,n,m,i,j,k,l,t,tot,now:longint; function min(x,y:longint):longint;
begin
if x<y then exit(x);
exit(y);
end; function max(x,y:longint):longint;
begin
if x<y then exit(y);
exit(x);
end; procedure lt(var x:longint);
var
k:longint;
begin
k:=right[x];
right[x]:=left[k];
left[k]:=x;
s[k]:=s[x];
s[x]:=s[left[x]]++s[right[x]];
x:=k;
end; procedure rt(var x:longint);
var
k:longint;
begin
k:=left[x];
left[x]:=right[k];
right[k]:=x;
s[k]:=s[x];
s[x]:=s[left[x]]++s[right[x]];
x:=k;
end; procedure maintain(var t:longint);
begin
if s[left[left[t]]]>s[right[t]] then begin
rt(t);
maintain(right[t]);
maintain(t);
exit;
end;
if s[right[left[t]]]>s[right[t]] then begin
lt(left[t]);
rt(t);
maintain(left[t]);
maintain(right[t]);
maintain(t);
exit;
end;
if s[right[right[t]]]>s[left[t]] then begin
lt(t);
maintain(left[t]);
maintain(t);
exit;
end;
if s[left[right[t]]]>s[left[t]] then begin
rt(right[t]);
lt(t);
maintain(left[t]);
maintain(right[t]);
maintain(t);
exit;
end;
end; procedure insert(var t:longint;x:longint);
begin
if t= then begin
inc(tot);
t:=tot;
left[t]:=;
right[t]:=;
value[t]:=x;
s[t]:=;
exit;
end;
inc(s[t]);
if x<=value[t] then insert(left[t],x)
else insert(right[t],x);
maintain(t);
end; function delete(var t:longint;x:longint):longint;
begin
dec(s[t]);
if (x=value[t]) or (x<value[t]) and (left[t]=) or (x>value[t]) and (right[t]=) then begin
delete:=value[t];
if (left[t]=) or (right[t]=) then t:=left[t]+right[t]
else
value[t]:=delete(left[t],value[t]+);
end
else
if x<value[t] then delete:=delete(left[t],x)
else delete:=delete(right[t],x);
end; function pred(t,x:longint):longint;
begin
if t= then exit(-mm);
if value[t]=x then exit(x);
if value[t]>x then exit(pred(left[t],x))
else
exit(max(value[t],pred(right[t],x)));
end; function succ(t,x:longint):longint;
begin
if t= then exit(mm);
if value[t]=x then exit(x);
if value[t]<x then exit(succ(right[t],x))
else
exit(min(value[t],succ(left[t],x)));
end; begin
readln(n);
now:=;
ans:=;
t:=;
while n> do begin
dec(n);
readln(i,j);
if i= then begin
if now>= then
insert(t,j)
else begin
k:=pred(t,j);
l:=succ(t,j);
if j-k<=l-j then begin
ans:=(ans+j-k)mod mmm;
delete(t,k);
end
else begin
ans:=(ans+l-j)mod mmm;
delete(t,l);
end;
end;
inc(now);
end
else begin
if now> then begin
k:=pred(t,j);
l:=succ(t,j);
if j-k<=l-j then begin
ans:=(ans+j-k)mod mmm;
delete(t,k);
end
else begin
ans:=(ans+l-j) mod mmm;
delete(t,l);
end;
end
else insert(t,j);
dec(now);
end;
end;
writeln(ans);
readln;
readln;
end.

bzoj1208: [HNOI2004]宠物收养所 (sbt)的更多相关文章

  1. BZOJ1208 HNOI2004 宠物收养所 【非旋转Treap】

    BZOJ1208 HNOI2004 宠物收养所 Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的 ...

  2. bzoj1208 [HNOI2004]宠物收养所(STL,Treap)

    1208: [HNOI2004]宠物收养所 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 5956  Solved: 2317[Submit][Sta ...

  3. 2018.07.06 BZOJ1208: HNOI2004宠物收养所(非旋treap)

    1208: [HNOI2004]宠物收养所 Time Limit: 10 Sec Memory Limit: 162 MB Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收 ...

  4. Bzoj1208 [HNOI2004]宠物收养所

    Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 7457  Solved: 2960 Description 最近,阿Q开了一间宠物收养所.收养所提供两 ...

  5. BZOJ1208[HNOI2004]宠物收养场——treap

    凡凡开了一间宠物收养场.收养场提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物. 每个领养者都希望领养到自己满意的宠物,凡凡根据领养者的要求通过他自己发明的一个特殊的公式,得出该领养者希望领 ...

  6. [bzoj1208][HNOI2004]宠物收养所——splay

    题目大意 Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发 ...

  7. [bzoj1208][HNOI2004][宠物收养所] (平衡树)

    Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发明的一个特 ...

  8. BZOJ1208 [HNOI2004]宠物收养所 splay

    原文链接http://www.cnblogs.com/zhouzhendong/p/8085803.html 题目传送门 - BZOJ1208 题意概括 有两种数,依次加入. 规则为下: 如果当前剩余 ...

  9. 【set】【Splay】【pb_ds】bzoj1208 [HNOI2004]宠物收养所

    每次来的如果是人,且宠物数不为零,就从宠物中选出一个与其差距最小的,累加答案:若为零,就把他放入另一个集合里. 如果是宠物,则同上. 各种平衡树都可过,我蛋疼地用了pb_ds. Code: #incl ...

随机推荐

  1. div仿textarea可输入

    原本要用textarea,但是后来发现好像只有IE支持textarea里边使用html标签,由于需要在textarea中显示一条横线(<hr />),在网上查了很久,都说textarea是 ...

  2. jQuery File Upload 文件上传插件使用一 (最小安装 基本版)

    jQuery File Upload 是一款非常强大的文件上传处理插件,支持多文件上传,拖拽上传,进度条,文件验证及图片音视频预览,跨域上传等等. 可以说你能想到的功能它都有.你没想到的功能它也有.. ...

  3. Maven项目配置tomcat插件实现项目自动部署到远程服务器

    1.tomcat配置 在tomcat目录中的conf目录下找到tomcat-users.xml配置文件,然后搜索tomcat-users,进行tomcat用户的角色和权限配置,如下: <tomc ...

  4. macOS 10.13 High Sierra PHP开发环境配置

    命令:sudo rm /usr/local/mysql sudo rm -rf /usr/local/mysql* sudo rm -rf /Library/StartupItems/MySQLCOM ...

  5. python里pickle模块

    Pickle模块用于将复杂的文件转化为二进制的文件 pickle模块一般是在源代码里面含有较大的字典或者列表等复杂文件时,我们如果将文件直接写在源代码里面,这样会使得代码很冗余,并且源代码文件所占空间 ...

  6. Unity Lighting - Lighting overview 照明概述

    Lighting overview 照明概述     In order to calculate the shading of a 3D object, Unity needs to know the ...

  7. C++0x,std::move和std::forward解析

    1.std::move 1.1std::move是如何定义的 template<typename _Tp> constexpr typename std::remove_reference ...

  8. TW实习日记:第28天

    同前两天一样,等接口,开发,调试接口.重复地做着低级代码得搬运工作,确实挺没意思的.怪不得有些人一直说写低级代码很无聊,没有创造性和成就感.31号准备溜了,还是好好复习准备秋招吧. 挖坑清单: Vue ...

  9. lintcode 平面列表

    问题描述: 给定一个列表,该列表中的每个要素要么是个列表,要么是整数.将其变成一个只包含整数的简单列表. 样例: 给定 [1,2,[1,2]],返回 [1,2,1,2]. 给定 [4,[3,[2,[1 ...

  10. Docker Remote API v1.24

    1. Brief introduction The Remote API has replaced rcli. The daemon listens on unix:///var/run/docker ...