【算法】平衡树(treap)

【题解】treap知识见数据结构

在POJ把语言从G++换成C++就过了……???

#include<cstdio>
#include<algorithm>
#include<ctime>
using namespace std;
const int maxn=;
struct cyc{int num,w,rnd,l,r;}t[maxn*];
int n,m,root,sz,s,tt,d[maxn];
void rr(int &tt)//右旋
{
int k=t[tt].l;
t[tt].l=t[k].r;
t[k].r=tt;
tt=k;
}
void lr(int &tt)
{
int k=t[tt].r;
t[tt].r=t[k].l;
t[k].l=tt;
tt=k;
}
void insert(int &w,int x)
{
if(w==)
{
w=++sz;
t[w].num=x;
t[w].w=;
t[w].rnd=rand();
return;
}
if(t[w].num==x){t[w].w++;return;};
if(x<t[w].num)
{
insert(t[w].l,x);
if(t[t[w].l].rnd<t[w].rnd)rr(w);
}
if(x>t[w].num)
{
insert(t[w].r,x);
if(t[t[w].r].rnd<t[w].rnd)lr(w);
}
}
void del(int &w,int x)
{
if(t[w].num==x)
{
if(t[w].w>)
{
t[w].w--;
return;
}
if(t[w].l*t[w].r==)w=t[w].l+t[w].r;//如果只有一颗子树,用这颗子树代替这个节点就可以删除了(没有子树则是用0代替之)。
else
if(t[t[w].l].rnd<t[t[w].r].rnd)
{
rr(w);
// del(t[w].r,x);
del(w,x);
}
else
{
lr(w);
// del(t[w].l,x);
del(w,x);
}
}
else if(t[w].num<x)del(t[w].r,x);
else del(t[w].l,x);
}
void find(int w,int x)
{
if(w==)return;
if(t[w].num>=x&&t[w].num<tt)tt=t[w].num;
if(t[w].num<=x&&t[w].num>s)s=t[w].num;
if(t[w].num>x)find(t[w].l,x);
if(t[w].num<x)find(t[w].r,x);
}
int main()
{
srand(time());
scanf("%d%d",&n,&m);
for(int i=,j=;i<=m;i++)
{
// printf("[]");
char c=getchar();int x;
c=getchar();//printf("[c=%c]",c);
// while(c<'A'&&c>'Z')c=getchar();
if(c=='D')
{
scanf("%d",&x);
insert(root,x);
d[++j]=x;
}
if(c=='R')del(root,d[j--]);
if(c=='Q')
{
s=,tt=n+;
scanf("%d",&x);
find(root,x);
if(s==tt)printf("0\n");
else printf("%d\n",tt-s-);
}
}
return ;
}

【POJ】2892 Tunnel Warfare的更多相关文章

  1. 【HDOJ】1540 Tunnel Warfare

    还不错的一道线段树区间合并.挺巧妙的用法. /* 1540 */ #include <iostream> #include <string> #include <map& ...

  2. 【POJ】1704 Georgia and Bob(Staircase Nim)

    Description Georgia and Bob decide to play a self-invented game. They draw a row of grids on paper, ...

  3. 【POJ】1067 取石子游戏(博弈论)

    Description 有两堆石子,数量任意,可以不同.游戏开始由两个人轮流取石子.游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子:二是可以在两堆中同时取走相同数量的石子.最后 ...

  4. hdu 1540/POJ 2892 Tunnel Warfare 【线段树区间合并】

    Tunnel Warfare                                                             Time Limit: 4000/2000 MS ...

  5. POJ 2892 Tunnel Warfare(线段树单点更新区间合并)

    Tunnel Warfare Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 7876   Accepted: 3259 D ...

  6. poj 2892 Tunnel Warfare(线段树)

    Tunnel Warfare Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 7499   Accepted: 3096 D ...

  7. 【BZOJ】【1986】【USACO 2004 Dec】/【POJ】【2373】划区灌溉

    DP/单调队列优化 首先不考虑奶牛的喜欢区间,dp方程当然是比较显然的:$ f[i]=min(f[k])+1,i-2*b \leq k \leq i-2*a $  当然这里的$i$和$k$都是偶数啦~ ...

  8. 【POJ】【2104】区间第K大

    可持久化线段树 可持久化线段树是一种神奇的数据结构,它跟我们原来常用的线段树不同,它每次更新是不更改原来数据的,而是新开节点,维护它的历史版本,实现“可持久化”.(当然视情况也会有需要修改的时候) 可 ...

  9. 【POJ】1222 EXTENDED LIGHTS OUT

    [算法]高斯消元 [题解] 高斯消元经典题型:异或方程组 poj 1222 高斯消元详解 异或相当于相加后mod2 异或方程组就是把加减消元全部改为异或. 异或性质:00 11为假,01 10为真.与 ...

随机推荐

  1. 结对作业二——WordCount进阶版

    软工作业三 要求地址 作业要求地址 结对码云项目地址 结对伙伴:秦玉 博客地址 PSP表格 PSP2.1 个人开发流程 预估耗费时间(分钟) 实际耗费时间(分钟) Planning 计划 10 7 · ...

  2. django使用ajax提交表单数据报403错解决方法

    只需要在.ajaxSetup方法中设置csrfmiddlewaretoken即可 $.ajaxSetup({ data: {csrfmiddlewaretoken: '{{ csrf_token }} ...

  3. Windows2008安装启用无线网卡

    昨天给本子换了系统来着,本来想法是好的,想在本子上安装Hyper-v来搭建多平台VPS,这样的话就能玩多个系统了,对于我自己来说对娱乐没啥兴趣,扯多了,正文 笔记本安装什么都很顺利,但是无线网卡把我难 ...

  4. sql server 带输入输出参数的分页存储过程(效率最高)

    create procedure proc_page_withtopmax( @pageIndex int,--页索引 @pageSize int,--每页显示数 @pageCount int out ...

  5. JAVA学习之泛型

    ArrayList<E>类定义和ArrayList<Integer>类引用中涉及的术语:1.整个ArrayList<E>称为泛型类型 2.ArrayList< ...

  6. 一致性Hash算法(Consistent Hash)

    分布式算法 在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括: 轮循算法(Round Robin).哈希算法(HASH).最少连接算法(Least Connection).响应速度算法(Re ...

  7. bzoj3864-hdu4899-Hero meet devil

    题目 给出一个由AGTC组成的字符串\(S\),长度为\(n\),对于每个\(i\in [0,n]\),问有多少个长度为\(m\),仅含有AGTC的字符串\(T\)使得\(S\)与\(T\)的最长公共 ...

  8. BZOJ4245 ONTAK2015 OR-XOR(贪心)

    贪心的按位考虑.如果所有数在某一位上有奇数个为1,显然无论如何划分这一位最终都会为1:否则将每一部分都划分为偶数个1就能保证最终该位为0,可以标记上哪些位置可以作为划分点(当然也要满足之前可为0的位上 ...

  9. [HAOI2010]计数 数位DP+组合数

    题面: 你有一组非零数字(不一定唯一),你可以在其中插入任意个0,这样就可以产生无限个数.比如说给定{1,2},那么可以生成数字12,21,102,120,201,210,1002,1020,等等. ...

  10. 【Winform】.cs文件命名空间排序及注释批量处理工具

    公司里每个程序员在命名空间的排序和注释上都有很多的不同. 杂乱的命名空间: using System; using System.Collections.Generic; using Autodesk ...