模板 SBT
傻逼树模板
struct SBT{
    const static int maxn = 1e5 + 15;
	int lft[maxn] , rht[maxn] , key[maxn] , s[maxn] , tot , root ;
	void init(){ tot = root = 0 ; }
	void init( int x , int val = 0 ){
		lft[x] = rht[x] = 0 , key[x] = val , s[x] = 1;
	}
	inline void up(int x){
        s[x] = s[lft[x]] + s[rht[x]] + 1;
    }
    void lr(int &t){
        int k = rht[t];
        rht[t] = lft[k];
        lft[k] = t;
        s[k] = s[t];
        up(t);
        t = k;
    }
    void rr(int &t){
        int k = lft[t];
        lft[t] = rht[k];
        rht[k]= t;
        s[k] = s[t];
        up(t);
        t = k;
    }
    void Maintain(int &t,bool dir){
        if(dir == false){
            if(s[lft[lft[t]]] > s[rht[t]])
                rr(t);
            else if(s[rht[lft[t]]] > s[rht[t]]){
                lr(lft[t]);
                rr(t);
            }
            else return;
        }
        else{
            if(s[rht[rht[t]]] > s[lft[t]]) lr(t);
            else if(s[lft[rht[t]]] > s[lft[t]]){
                rr(rht[t]);
                lr(t);
            }
            else return;
        }
        Maintain(lft[t],false);
        Maintain(rht[t],true);
        Maintain(t,true);
        Maintain(t,false);
    }
	void Insert( int & t , int val ){
		if( t == 0 ){
			t = ++ tot;
			init( t , val );
		}else{
			++ s[t];
			if( val < key[t] ) Insert( lft[t] , val );
			else Insert( rht[t] , val );
			Maintain( t , val >= key[t] );
		}
	}
	// 删除操作必须保证元素存在
    int Delete(int &t , int v){
        int ret = 0;
        s[t] --;
        if((v == key[t]) || (v<key[t] && lft[t]  == 0) ||(v > key[t] && rht[t] == 0) ){
            ret = key[t];
            if(lft[t] == 0 || rht[t] == 0) t = lft[t] + rht[t];
            else key[t]  = Delete(lft[t],key[t] + 1);
        }
        else{
            if(v < key[t]) ret = Delete(lft[t] , v);
            else ret = Delete(rht[t] , v);
        }
        return ret;
    }
    bool find( int t , int val ){
    	if( t == 0 ) return false;
    	else if( key[t] == val ) return true;
    	else if( val < key[t] ) return find( lft[t] , val );
    	else return find( rht[t] , val );
    }
    void preorder( int x ){
    	if( lft[x] ) preorder( lft[x] );
    	printf("%d " , key[x]);
    	if( rht[x] ) preorder( rht[x] );
    }
    int size(){
    	return s[root];
    }
    // 查第 k 小 , 必须保证合法
    int kth( int x , int k ){
    	if( k == s[lft[x]] + 1 ) return key[x];
    	else if( k <= s[lft[x]] ) return kth( lft[x] , k );
    	else return kth( rht[x] , k - s[lft[x]] - 1 );
    } 
    //找前驱
    int pred( int t , int v ){
    	if( t == 0 ) return v;
    	else{
    		if( v <= key[t] ) return pred( lft[t] , v );
    		else{
    			int ans =  pred( rht[t] , v );
    			if( ans == v ) ans = key[t];
    			return ans;
    		}
    	}
    }
    // 严格小于 v 的有多少个
    int less( int t , int v ){
    	if( t == 0 ) return 0;
    	if( v <= key[t] ) return less( lft[t] , v );
    	else return s[lft[t]] + 1 + less( rht[t] , v );
    }
    //找后继
    int succ( int t , int v ){
    	if( t == 0 ) return v;
    	else{
    		if( v >= key[t] ) return succ( rht[t] , v );
    		else{
    			int ans =  succ( lft[t] , v );
    			if( ans == v ) ans = key[t];
    			return ans;
    		}
    	}
    }
}sbt;模板 SBT的更多相关文章
- 三大平衡树(Treap + Splay + SBT)总结+模板[转]
		Treap树 核心是 利用随机数的二叉排序树的各种操作复杂度平均为O(lgn) Treap模板: #include <cstdio> #include <cstring> #i ... 
- 子树大小平衡树(Size Balanced Tree,SBT)操作模板及杂谈
		基础知识(包括但不限于:二叉查找树是啥,SBT又是啥反正又不能吃,平衡树怎么旋转,等等)在这里就不(lan)予(de)赘(duo)述(xie)了. 先贴代码(数组模拟): int seed; int ... 
- Size Balanced Tree(SBT) 模板
		首先是从二叉搜索树开始,一棵二叉搜索树的定义是: 1.这是一棵二叉树: 2.令x为二叉树中某个结点上表示的值,那么其左子树上所有结点的值都要不大于x,其右子树上所有结点的值都要不小于x. 由二叉搜索树 ... 
- HDU 4006 The kth great number 优先队列、平衡树模板题(SBT)
		The kth great number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Oth ... 
- 平衡树初阶——AVL平衡二叉查找树+三大平衡树(Treap + Splay + SBT)模板【超详解】
		平衡树初阶——AVL平衡二叉查找树 一.什么是二叉树 1. 什么是树. 计算机科学里面的树本质是一个树状图.树首先是一个有向无环图,由根节点指向子结点.但是不严格的说,我们也研究无向树.所谓无向树就是 ... 
- 洛谷P3369 【模板】普通平衡树(Treap/SBT)
		洛谷P3369 [模板]普通平衡树(Treap/SBT) 平衡树,一种其妙的数据结构 题目传送门 题目描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 插入x数 删除 ... 
- [luogu P3369]【模板】普通平衡树(Treap/SBT)
		[luogu P3369][模板]普通平衡树(Treap/SBT) 题目描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 插入x数 删除x数(若有多个相同的数,因只删 ... 
- 三大平衡树(Treap + Splay + SBT)总结+模板[转]
		Treap树 核心是 利用随机数的二叉排序树的各种操作复杂度平均为O(lgn) Treap模板: #include <cstdio> #include <cstring> #i ... 
- 三大平衡树(Treap + Splay + SBT)总结+模板
		Treap树 核心是 利用随机数的二叉排序树的各种操作复杂度平均为O(lgn) Treap模板: #include <cstdio> #include <cstring> #i ... 
随机推荐
- fcntl函数的用法总结
			fcntl系统调用可以用来对已打开的文件描述符进行各种控制操作以改变已打开文件的的各种属性 函数原型: #include<unistd.h> #include<fcntl.h&g ... 
- C#中HttpWebRequest的GetRequestStream执行的效率太低,甚至偶尔死掉
			为了提高httpwebrequest的执行效率,查到了一些如下设置 request.ServicePoint.Expect100Continue = false; request.ServicePoi ... 
- mac搭建lamp环境
			转载:https://www.cnblogs.com/beautiful-code/p/7465320.html 
- 如何从TFS(Visual Studio Team Foundation Server)映射下载本地文件夹
			1.连接tfs项目 首先打开vs2017 ——>工具栏 中的 团队——> 选择团队的管理链接 2.选择管理工作区 显示管理工作区的弹窗,点击 编辑 显示弹窗,选择本地文件夹(即要保存 ... 
- java基础38 正则表达式
			1.常用的正则表达式 预定义字符类:. 任何字符(与行结束符可能匹配也可能不匹配) \d 数字:[0-9] \D 非数字: [^0-9] \s 空白字符:[ \t\n\x0B\f\r] \S ... 
- PlantUML——4.实例演示1
			给自己发消息 @startuml Alice -> Alice : This is a signal to self.\nIt also demonstrates \nmultiline tex ... 
- java多线程-读写锁原理
			Java5 在 java.util.concurrent 包中已经包含了读写锁.尽管如此,我们还是应该了解其实现背后的原理. 读/写锁的 Java 实现(Read / Write Lock Java ... 
- gcc/g++ 命令
			gcc & g++现在是gnu中最主要和最流行的c & c++编译器 .g++是c++的命令,以.cpp为主,对于c语言后缀名一般为.c.这时候命令换做gcc即可.其实是无关紧要的.其 ... 
- (三)Jsoup 使用选择器语法查找 DOM 元素
			第一节: Jsoup 使用选择器语法查找 DOM 元素 Jsoup使用选择器语法查找DOM元素 我们前面通过标签名,Id,Class样式等来搜索DOM,这些是不能满足实际开发需求的, 很多时候我们需要 ... 
- Oracle与Sqlserver数据共享
			需求:在一个集成平台中有一个主系统使用的是Oralce数据库,子系统使用的SqlServer 数据库,如何让子系统的数据库与主系统的人员同步呢? 思路:通过服务WebService 公开接口 1.与主 ... 
