SBT 模板不完全总结,后续待填

  1 #include<iostream>
  2 #include<cstring>
  3 #include<cstdio>
  4 #include<algorithm>
  5 #define N 100005
  6 using namespace std;
  7 struct SBT{
  8     //左子树指针,右子树指针,大小,键值
  9     int left,right,size,key;
 10     void Init(){
 11         left=right=key=0;
 12         size=1;
 13     }
 14 }T[N];
 15 int root,tot; //根的位置以及节点个数
 16 //左旋转处理
 17 void Left_rot(int &x){  
 18     int k=T[x].right;
 19     T[x].right=T[k].left;
 20     T[k].left=x;
 21     T[k].size=T[x].size;
 22     T[x].size=T[T[x].left].size+T[T[x].right].size+1;
 23     x=k;
 24 }
 25 //右旋转处理
 26 void Right_rot(int &x){
 27     int k=T[x].left;
 28     T[x].left=T[k].right;
 29     T[k].right=x;
 30     T[k].size=T[x].size;
 31     T[x].size=T[T[x].left].size+T[T[x].right].size+1;
 32     x=k;
 33 }
 34 //调整处理
 35 void Maintain(int &r,bool flag){
 36     if(flag){  //更新右子树
 37         if(T[T[T[r].right].right].size>T[T[r].left].size)
 38             Left_rot(r);
 39         else if(T[T[T[r].right].left].size>T[T[r].left].size){
 40             Right_rot(T[r].right);
 41             Left_rot(r);
 42         }
 43         else
 44             return;
 45     } 
 46     else{   //更新在左子树
 47         if(T[T[T[r].left].left].size>T[T[r].right].size)
 48             Right_rot(r);
 49         else if(T[T[T[r].left].right].size>T[T[r].right].size){
 50             Left_rot(T[r].left);
 51             Right_rot(r);
 52         }
 53         else 
 54             return;
 55     }
 56     //更新子树,然后再更新根,直到平衡为止
 57     Maintain(T[r].left,false);
 58     Maintain(T[r].right,true);
 59     Maintain(r,false);
 60     Maintain(r,true);
 61 }
 62 //插入新节点
 63 void Insert(int &r,int k){
 64     if(r==0){
 65         r=++tot;
 66         T[r].Init();
 67         T[r].key=k;
 68     }
 69     else{
 70         T[r].size++;
 71         if(k<T[r].key)
 72             Insert(T[r].left,k);
 73         else
 74             Insert(T[r].right,k);
 75         //插入后要调整,保证平衡
 76         Maintain(r,k>=T[r].key);
 77     }
 78 }
 79 //删除结点,利用的是前驱替换
 80 int Remove(int &r,int k){
 81     int d_key;
 82     if(!r)
 83         return 0;
 84     T[r].size--;
 85     //前者说明就是要删的节点,后两者说明不存在此节点
 86     if(T[r].key==k||(T[r].left==0&&k<T[r].key)||(T[r].right==0&&k>T[r].key)){
 87         d_key=T[r].key;
 88         if(T[r].left&&T[r].right)
 89             T[r].key=Remove(T[r].left,k+1);
 90         else
 91             r=T[r].left+T[r].right;
 92     }
 93     else Remove(k<T[r].key?T[r].left:T[r].right,k);
 94 }
 95 void Delete(int &r,int delay,int min_val){
 96     if(!r) return;
 97     if(T[r].key+delay<min_val) {
 98         r=T[r].right;
 99         Delete(r,delay,min_val);
100     }
101     else{
102         Delete(T[r].left,delay,min_val);
103         T[r].size=T[T[r].right].size+T[T[r].left].size+1;
104     }
105 }
106 //取得最大值,即一直遍历到最右的结点
107 int Get_Max(int &r){
108     while(T[r].right)
109         r=T[r].right;
110     return r;
111 }
112 //取得最小值,即一直遍历到最左的结点
113 int Get_Min(int &r){
114     while(T[r].left)
115         r=T[r].left;
116     return r;
117 }
118 //获得前驱
119 int Get_Pre(int &r,int y,int k){
120     if(r==0return y;
121     if(k>T[r].key)
122         Get_Pre(T[r].right,r,k);
123     else
124         Get_Pre(T[r].left,y,k);
125 }
126 //获得后继
127 int Get_Next(int &r,int y,int k){
128     if(r==0return y;
129     if(k<T[r].key)
130         Get_Next(T[r].left,r,k);
131     else
132         Get_Next(T[r].right,y,k);
133 }
134 //取得第K小的数,注:暂不能解决有重复数的
135 int Get_Min_Kth(int &r,int k){
136     int t=T[T[r].left].size+1;
137     if(t==k) return T[r].key;
138     if(t<k)  return Get_Min_Kth(T[r].right,k-r);
139     else return Get_Min_Kth(T[r].left,k);
140 }
141 //取得第K大的数
142 int Get_Max_Kth(int &r,int k){
143     int t=T[T[r].right].size+1;
144     if(t==k) return T[r].key;
145     if(t<k) return Get_Max_Kth(T[r].left,k-t);
146     else return Get_Max_Kth(T[r].right,k);
147 }
148 //获得结点的名次
149 int Get_Rank(int &r,int k){
150     if(k<T[r].key) 
151         return Get_Rank(T[r].left,k);
152     else if(k>T[r].key)
153         return Get_Rank(T[r].right,k)+T[T[r].left].size+1;
154     else
155         return T[T[r].left].size+1;
156 }
157 //排序
158 void Inorder(int &r){
159     if(r==0return;
160     Inorder(T[r].left);
161     printf("%d\n",T[r].key);
162     Inorder(T[r].right);
163 }
posted @ 2014-08-17 17:44  acvc  阅读(271)  评论(0编辑  收藏  举报