青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

bon

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  46 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

今天實現了《算法導論》里提到的二叉搜索樹。
支持的操作有:插入、刪除、查詢、前驅、后繼、遍歷等。
首先定義樹節點的結構體:
struct node{
    node(
long k,int position){
        l
=r=p=NULL;
        key
=k,pos=position;
    }
    node(){
        l
=r=p=NULL;
    }
    node 
*l,*r,*p;
    
int pos;
    
long key;
};

1. 插入操作
    
void insert(long k,int position)
{
    node 
*yy=NULL;
    node 
*xx = root;
    
while(xx!=NULL){
        yy
=xx;
        
if(k>xx->key) xx=xx->r;
        
else xx=xx->l;
    }
    node 
*z=new node(k,position);
    z
->p=yy;
    
// 空樹
    if(yy==NULL) root=z;
    
else{
        
if(yy->key<z->key) yy->r=z;
        
else yy->l=z;
    }
}
插入就是將新的鍵值放到合適的位置,使得二叉搜索樹的性質得以保存。
用兩個指針yy,xx,yy指向xx的父節點。xx跟yy同時向下搜索:當待插入鍵值小于xx指向的節點鍵值時,xx指向xx的左兒子,否則指向右兒子。yy跟進。直到xx為空,說明到達合適的位置了,此時建立新的節點并把信息存進去。修改yy所指的節點(此時為新節點的父節點)的兒子指針。

2. 刪除操作
刪除操作比較復雜一些,先看下面的代碼:
 1 bool del(long key,node &res)
 2 {
 3     node *z=search(key);
 4     if(z==NULL) return false;
 5     
 6     node *y;
 7     if(z->==NULL || z->r==NULL) y=z;
 8     else y=successor(z->key);
 9     
10     // x指向y的非空兒子,此時y最多只有一個兒子。若y無兒子,x為空
11     node *x;
12     if(y->l!=NULL) x=y->l;
13     else x=y->r;
14 
15     // y有一個兒子,則將y刪去
16     if(x!=NULL)    x->p=y->p;
17     
18     // y is the root
19     if(y->p==NULL) root=x;
20     else{
21         if(y==y->p->l) (y->p)->l=x;
22         else y->p->r=x;
23     }
24 
25     // 當y!=z時,則y是z的后繼,刪去z后,y取代z
26     if(y!=z) z->key=y->key,z->pos=y->pos;
27     res.key=z->key,res.pos=z->pos;
28     delete y;
29     return true;
30 }
刪除鍵值為k的節點時,首先要找到這個節點,用函數node *search(long k),返回一個指針指向包含該鍵值的節點(如第3行所示)。
接下來分三種情況:
被刪節點無孩子、只有一個孩子、有兩個孩子。
若是情況1或2,y指向被刪節點,否則指向被刪節點的后繼,如6~8行所示。這個操作后,y所指向的節點至多只有1個孩子(想想為什么)
接著指針x指向y唯一的孩子(若有的話)并改變x的父親指針,指向y的父節點(注意此時y的父親指針仍指向y的父親)
19~23行處理y是根的情況;26行處理case3的情況。
最后刪除y,并以引用變量res返回被刪的節點的信息。
3. 搜索
包括找一個鍵值k,找鍵值k的前驅、后繼,最大最小值。
原理比較簡單,代碼如下:
 1 // 返回以x為根的子樹的最小值
 2 node *minimum(node *x)
 3 {
 4     while(x->l!=NULL) x=x->l;
 5     return x;
 6 }
 7 
 8 node *maximum(node *x)
 9 {
10     while(x->r!=NULL) x=x->r;
11     return x;
12 }
13 
14 // 返回x的后繼,即比x大的數中最小的一個
15 node *successor(long k)
16 {
17     node *x=search(k);
18     node *y=NULL;
19     if(x->r!=NULL) return minimum(x->r);
20     else{
21         y=x->p;
22         while(y!=NULL && x==y->r){
23             x=y;
24             y=x->p;
25         }
26     }
27     // 若y==NULL 則x為根節點且無后繼
28     return y;
29 }
30 
31 node *predecessor(long k)
32 {
33     node *x=search(k);
34     node *y=NULL;
35     if(x->l!=NULL) return maximum(x->l);
36     else{
37         y=x->p;
38         while(y!=NULL && x==y->l){
39             x=y;
40             y=x->p;
41         }
42     }
43     return y;
44 }
4. 中序遍歷
   相當于是從小到大輸出樹中節點的鍵值。
1 void inorderWalk(node *x)
2 {
3     if(x!=NULL){
4         inorderWalk(x->l);
5         printf("%d ",x->key);
6         inorderWalk(x->r);
7     }
8 }

posted on 2008-03-07 20:52 bon 閱讀(520) 評論(0)  編輯 收藏 引用 所屬分類: Notes on Introduction to Algorithms

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


Google PageRank 
Checker - Page Rank Calculator
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲影视中文字幕| 欧美色欧美亚洲另类七区| 亚洲——在线| 国语精品一区| 亚洲欧美在线一区二区| 亚洲韩日在线| 久久久精品国产免费观看同学 | 中国av一区| 欧美在线网站| 亚洲一区二区三区影院| 免费观看成人网| 一区二区三区在线视频播放| 国产综合色在线| 国产一区二区高清不卡| 在线亚洲成人| 国产精品日本精品| 亚洲影院在线| 欧美日韩精品一区视频| 性刺激综合网| 午夜伦理片一区| 亚洲国产欧美久久| 女生裸体视频一区二区三区| 最新国产成人在线观看| 亚洲精品国产欧美| 欧美日韩高清一区| 久久精品首页| 欧美成人精品高清在线播放| 欧美日韩在线一区| 久久精品综合一区| 日韩天堂在线视频| 在线看一区二区| 欧美日韩视频在线一区二区观看视频 | 性亚洲最疯狂xxxx高清| 午夜精品福利一区二区三区av| 欧美风情在线观看| 亚洲毛片av| 欧美亚洲一区三区| 黄色精品免费| 久久福利一区| 久久青青草综合| av成人动漫| 亚洲欧美色婷婷| 亚洲高清不卡av| 国产亚洲一级高清| 欧美日本在线看| 亚洲欧美一区二区精品久久久| 中文精品视频| 亚洲一级片在线观看| 国产精品区二区三区日本| 宅男精品视频| 另类亚洲自拍| 久久一区精品| 亚洲欧洲精品一区二区| 亚洲一区二区三区在线播放| 欧美日韩精品是欧美日韩精品| 久久不射网站| 亚洲电影观看| 欧美精品手机在线| 小嫩嫩精品导航| 亚洲国产一区二区三区青草影视| 国产精品视频精品| 欧美日韩国产一中文字不卡| 久久久国产亚洲精品| 亚洲色图在线视频| 亚洲天天影视| 奶水喷射视频一区| 国产日韩精品入口| 亚洲欧美日韩国产中文在线| 国产美女精品在线| 欧美一级午夜免费电影| 久久久99久久精品女同性| 久久久久亚洲综合| 亚洲福利免费| 午夜视频一区二区| 亚洲电影中文字幕| 国产日韩欧美综合精品| 久久久久久色| 一本到12不卡视频在线dvd| 狠狠干综合网| 一区二区三区欧美在线| 久久福利毛片| 性欧美大战久久久久久久免费观看| 激情综合五月天| 亚洲免费观看在线视频| 一区二区三区日韩| 亚洲电影免费观看高清完整版| 亚洲精品视频在线| 国产视频自拍一区| 国产亚洲精品久久久久婷婷瑜伽| 欧美一区二区三区电影在线观看| 欧美大片国产精品| 欧美伊人久久大香线蕉综合69| 黄色av成人| 国产欧美日韩视频在线观看| 亚洲香蕉在线观看| 午夜久久影院| 亚洲黄色影片| 免费亚洲电影在线观看| 欧美日韩免费观看一区二区三区 | 亚洲一区二区三区四区五区午夜| 欧美日韩国产一中文字不卡| 亚洲精一区二区三区| 国产精品一二三| 国产亚洲精久久久久久| 欧美日韩日日骚| 国产精品视频精品视频| 欧美性事免费在线观看| 欧美日韩国产三区| 国产丝袜一区二区| 精品成人一区二区| 一本色道久久加勒比88综合| 国产自产v一区二区三区c| 欧美在线视频一区| 国产久一道中文一区| 日韩午夜av电影| 亚洲伊人观看| 亚洲激情欧美| 一区二区成人精品| 伊甸园精品99久久久久久| 午夜精彩视频在线观看不卡| 日韩网站在线看片你懂的| 国产精品超碰97尤物18| 国产日韩精品在线观看| 一区二区三区www| 香蕉亚洲视频| 久久久午夜电影| 国产午夜精品久久久| 在线观看视频免费一区二区三区| 亚洲最新在线| 亚洲精品日韩欧美| 欧美激情中文字幕乱码免费| 欧美精品情趣视频| 欧美11—12娇小xxxx| 亚洲高清一二三区| 欧美在线观看视频在线| 一区二区日本视频| 免费视频久久| 欧美一区视频| 欧美视频在线一区二区三区| 亚洲神马久久| 韩曰欧美视频免费观看| 久久精品国产999大香线蕉| 欧美精品一区二区在线播放| 欧美丝袜一区二区| 午夜精品免费| 欧美亚洲三区| 在线观看一区二区视频| 久久久久免费| 久久久久久噜噜噜久久久精品| 国产亚洲午夜| 亚洲国产岛国毛片在线| 你懂的国产精品| 国产精品v亚洲精品v日韩精品 | 亚洲欧美色婷婷| 欧美另类女人| 亚洲愉拍自拍另类高清精品| 中文一区二区| 久久久久久9999| 免费成人高清视频| 亚洲女性裸体视频| 欧美国产日韩在线观看| 一本色道久久精品| 亚洲一二三区在线| 久久久久国色av免费观看性色| 国产视频在线观看一区 | 亚洲成人中文| 亚洲直播在线一区| 欧美另类一区| 一区二区成人精品| 欧美国产激情二区三区| 狠狠综合久久av一区二区老牛| 午夜精品短视频| 亚洲韩国精品一区| 亚洲欧美日韩精品| 亚洲精品1区2区| 国产精品久久久久av| 亚洲精品视频一区二区三区| 久久国产主播精品| 欧美成人综合一区| 亚洲承认在线| 亚洲日本va午夜在线电影| 99re66热这里只有精品3直播 | 亚洲破处大片| 亚洲福利视频三区| 免费在线看一区| 亚洲国产成人av好男人在线观看| 国产欧美一区二区在线观看| 国产日产亚洲精品| 欧美国产日本韩| 久久精品91| 久久青草福利网站| 久久先锋资源| 欧美亚洲视频一区二区| 亚洲精品美女91| 亚洲视频专区在线| 欧美日韩视频专区在线播放| 午夜精品理论片| 韩曰欧美视频免费观看| 欧美一区二区三区四区在线观看 | 亚洲精品影视|