小C的树(Treap节点删除)[70/100]
用Treap暴力模拟,调常数~
好了,接下来说一下Treap中的删除操作
Step 1:先找到这个结点。
Step 2:如果它的儿子≤1,用它儿子替它
否则 把之后做根节点的儿子旋转到根
回到Step 1.
居然不会……我可以去面壁了……
话说更新Blog真是开心(蒟蒻的Blog几近没人看)
膜拜自建站的。
//话说跑题了啊……%
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<functional>
#include<iostream>
#include<cmath>
#include<cctype>
#include<ctime>
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define Rep(i,n) for(int i=0;i<n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define RepD(i,n) for(int i=n;i>=0;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define Lson (x<<1)
#define Rson ((x<<1)+1)
#define MEM(a) memset(a,0,sizeof(a));
#define MEMI(a) memset(a,127,sizeof(a));
#define MEMi(a) memset(a,128,sizeof(a));
#define INF (2139062143)
#define F (100000007)
#define MAXN (200000+10)
long long mul(long long a,long long b){return (a*b)%F;}
long long add(long long a,long long b){return (a+b)%F;}
long long sub(long long a,long long b){return (a-b+(a-b)/F*F+F)%F;}
struct node
{
int ch[2],v,r;
node():v(0),r(0){ch[0]=ch[1]=0;}
node(int _v,int _r):v(_v),r(_r){ch[0]=ch[1]=0;}
}q[MAXN];
int root=0,tail=0;
void rotate(int &x,int p)
{
int y=q[x].ch[p^1];q[x].ch[p^1]=q[y].ch[p];q[y].ch[p]=x;x=y;
}
void insert(int &x,int p)
{
if (!x) {x=p;return;}
bool p2=q[p].v>q[x].v;
insert(q[x].ch[p2],p);
if (q[x].r<q[q[x].ch[p2]].r) rotate(x,p2^1);
}
void delet(int &x,int v)
{
if (!x) return;
if (q[x].v==v)
{
int y1=q[x].ch[0],y2=q[x].ch[1];
if (!y1&&!y2) {x=0;return;}
if (y1&&!y2) {x=q[x].ch[0];return;}
if (!y1&&y2) {x=q[x].ch[1];return;}
int p=q[y2].r>q[y1].r,y=q[x].ch[p];
/*
swap(q[x].v,q[y].v);swap(q[x].r,q[y].r);
delet(y,v);*/
rotate(x,p^1);
delet(x,v);
}
if (v<q[x].v) delet(q[x].ch[0],v);
else delet(q[x].ch[1],v);
}
int find(int x,bool is_d,int u,int v)
{
int ans=0;
if (!is_d)
{
if (q[x].v==u) return find(x,1,v,0);
if (q[x].v==v) return find(x,1,u,0);
int p1=u>q[x].v,p2=v>q[x].v;
if (p1==p2) return find(q[x].ch[p1],0,u,v);
else return 2+find(q[x].ch[p1],1,u,0)+find(q[x].ch[p2],1,v,0);
}
else
{
if (q[x].v==u) return 0;
int p=u>q[x].v;
return 1+find(q[x].ch[p],1,u,0);
}
}
int m;
int main()
{
freopen("c.in","r",stdin);
freopen("c.out","w",stdout);
scanf("%d",&m);
For(i,m)
{
int p;
scanf("%d",&p);
if (p==0)
{
int v,r;
scanf("%d%d",&v,&r);
q[++tail]=node(v,r);
insert(root,tail);
}
else if (p==1)
{
int v;
scanf("%d",&v);
delet(root,v);
}
else
{
int u,v;
scanf("%d%d",&u,&v);
if (u==v) puts("0");
else cout<<find(root,0,u,v)<<endl;
} } return 0;
}
小C的树(Treap节点删除)[70/100]的更多相关文章
- BZOJ_1901_&_ZJU_2112_Dynamic_Rankings_(主席树+树状数组/线段树+(Treap/Splay))
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1901 给出一个长度为n的数列A,有m次询问,询问分两种:1.修改某一位置的值;2.求区间[l, ...
- 【codevs2370】小机房的树 LCA 倍增
2370 小机房的树 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 小机房有棵焕狗种的树,树上有N个节点,节点标号为0 ...
- 小机房的树 codevs 2370
2370 小机房的树 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 小机房有棵焕狗种的树 ...
- Codevs 2370 小机房的树
2370 小机房的树 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 小机房有棵焕狗种的树,树上有N个节点,节点标号为 ...
- 牛客挑战赛30 小G砍树 树形dp
小G砍树 dfs两次, dp出每个点作为最后一个点的方案数. #include<bits/stdc++.h> #define LL long long #define fi first # ...
- CodeVs.2370 小机房的树 ( LCA 倍增 最近公共祖先)
CodeVs.2370 小机房的树 ( LCA 倍增 最近公共祖先) 题意分析 小机房有棵焕狗种的树,树上有N个节点,节点标号为0到N-1,有两只虫子名叫飘狗和大吉狗,分居在两个不同的节点上.有一天, ...
- LCA(倍增在线算法) codevs 2370 小机房的树
codevs 2370 小机房的树 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 小机房有棵焕狗种的树,树上有N个节点, ...
- 【BZOJ5072】[Lydsy十月月赛]小A的树 树形DP
[BZOJ5072][Lydsy十月月赛]小A的树 题解:考虑我们从一个联通块中替换掉一个点,导致黑点数量的变化最多为1.所以我们考虑维护对于所有的x,y的最大值和最小值是多少.如果询问的y在最大值和 ...
- codevs——2370 小机房的树
2370 小机房的树 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 小机房有棵焕狗种的树,树上有N个 ...
随机推荐
- 查询DBlink创建
DBlink创建 查询 博客分类: Oracle 当用户要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的dblink,通过dblink本地数据库可以像访问本地数据 ...
- CSS3实战开发: 纯CSS实现图片过滤分类显示特效
原文:CSS3实战开发: 纯CSS实现图片过滤分类显示特效 各位网友大家好,今天我要带领大家开发一个纯CSS的图片分类显示的网址导航,单纯看标题大家可能有些困惑,依照以往惯例,我先给大家演示一下实际运 ...
- Java程序单元测试工具对比——Parasoft Jtest与Junit
Web应用程序开发中,面向对象的Java语言占了不少的比重.对于Java应用程序的测试方法或方式多种多样,比较典型的是程序员自己来完成程序测试中的一个部分——单元测试. 之前,慧都资讯提到单元测试是程 ...
- 对web.config的ConnectionString加密
原文:对web.config的ConnectionString加密 本文参考了wayshan的博客,原文地址:http://www.cnblogs.com/wayshan/archive/2012/0 ...
- PDF解决方案(4)--在线浏览
相关专题链接 PDF解决方案(1)--文件上传 PDF解决方案(2)--文件转PDF PDF解决方案(3)--PDF转SWF PDF解决方案(4)--在线浏览 前言:上一篇主要提到了PDF在线浏览的各 ...
- 异步提交form的时候利用jQuery validate实现表单验证
异步提交form的时候利用jQuery validate实现表单验证相信很多人都用过jquery validate插件,非常好用,并且可以通过下面的语句来自定义验证规则 // 电话号码验证 ...
- mediawiki在windows下的安装
mediawiki在windows下的安装 对于刚接触wiki的朋友们来说,配置一个服务器环境,安装并运行mediawiki是一件很麻烦的事情,在这里,我尽量用通俗易懂的语言,介绍mw(mediawi ...
- Android项目---HtmlParse
在解析网站上的内容的时候,总会出现很多html的标签,一般在遇到这种数据的时候,就可以用上Html 如: content.setText(Html.fromHtml("<html> ...
- 大规模web服务开发技术
大规模web服务开发技术 总评 这本书是日本一个叫hatena的大型网站的CTO写的,通过hatena网站从小到大的演进来反应一个web系统从小到大过程中的各种系统和技术架构变迁,比较接 ...
- 【值得收藏】绘图工具Origin的学习资料汇编【可免费下载】
Origin使用教程 Origin为OriginLab公司出品的较流行的专业函数绘图软件,是公认的简单易学.操作灵活.功能强大的软件,既可以满足一般用户的制图需要,也可以满足高级用户数据分析.函数拟合 ...