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

Problem Solving using C++

Algorithm Study using C++

二叉搜索樹操作(2)--其他

#include <iostream>
#include 
<cstdlib>
using namespace std;

#ifndef NULL
#define NULL 
0
#endif

#ifndef MAXSIZE
#define MAXSIZE    
10
#endif

typedef struct BST
//Binary Search Tree
{
    
int key;
    
//maybe there are some other satellites
    
    struct BST
* left;
    struct BST
* right;
    struct BST
* parent;
} BST;

BST
* root=NULL;

void BST_Insert(int key)//add value key to the Binary Search Tree
{
    BST
* y=NULL;//y records the parent node
    BST* x=root;//x records the current node
    
    BST
* node = new BST();
    node
->key = key;
    node
->left = NULL;
    node
->right = NULL;
    node
->parent = NULL;
    
    
while(x!=NULL)
    {
        y
=x;
        
        
if(key<x->key)
            x
=x->left;
        
else
            x
=x->right;
    }
    
    node
->parent=y;
    
    
if(y==NULL)
        root 
= node;
    
else
    {
        
if(key<y->key)
            y
->left=node;
        
else
            y
->right=node;
    }
}

void BST_Delete(BST* p)
{
    
if(p)
    {
        BST_Delete(p
->left);
        BST_Delete(p
->right);
        delete p;
    }
}

void BST_Build()
{
    
int temp;
    
    cout
<<"Original Input:"<<endl;
    
for(int i=0;i<MAXSIZE;i++)
    {
        temp
=rand()%MAXSIZE;
        cout
<<temp<<" ";
        BST_Insert(temp);
    }
    cout
<<endl;
}

void BST_Inorder_Walk(BST* p)
{
    
    
if(p)
    {
        BST_Inorder_Walk(p
->left);
        cout
<<p->key<<" ";
        BST_Inorder_Walk(p
->right);
    }
}

void BST_Preorder_Walk(BST* p)
{
    
    
if(p)
    {
        cout
<<p->key<<" ";
        BST_Preorder_Walk(p
->left);
        BST_Preorder_Walk(p
->right);
    }
}

void BST_Postorder_Walk(BST* p)
{
    
if(p)
    {
        BST_Postorder_Walk(p
->left);
        BST_Postorder_Walk(p
->right);
        cout
<<p->key<<" ";
    }
}

BST
* BST_Search(int key)
{
    BST
* x=root;
    
    
while(x)
    {
        
if(x->key==key)
            
return x;
        
else
            
if(x->key>key)
                x
=x->left;
            
else
                x
=x->right;
    }
    
    
return NULL;    
}

BST
* BST_Min(BST* p=root)
{
    
//BST* p = root;
    
    
while(p->left)
    {
        p
=p->left;
    }
    
    
return p;
}

BST
* BST_Max(BST* p=root)
{
    
//BST* p = root;
    
    
while(p->right)
    {
        p
=p->right;
    }
    
    
return p;
}

BST
* BST_Successor(int key)
{
    BST
* p = BST_Search(key);
    BST
* y;
    
    
if(p)
    {
        
if(p->right)
        {
            
return BST_Min(p->right);
        }
        
        y
=p->parent;
        
while(y&&(y->right==p))
        {
            p
=y;
            y
=y->parent;
        }
        
        
return y;
    }
    
    
return NULL;
}

BST
* BST_Predecessor(int key)
{
    BST
* p = BST_Search(key);
    BST
* y;
    
    
if(p)
    {
        
if(p->left)
            
return BST_Max(p->left);
        
        y
=p->parent;
        
while(y&&(y->left==p))
        {
            p
=y;
            y
=y->parent;
        }
        
        
return y;
    }
    
    
return p;
}

BST
* BST_Delete(int key)
{
    BST
* p = BST_Search(key);
    BST
* y,*x;
    
    
if(p)
    {
        
if(!p->left||!p->right)
        {
            y
=p;
        }
        
else
            y
=BST_Successor(key);
            
        
if(y->left)
            x
=y->left;
        
else
            x
=y->right;
        
        
if(x!=NULL)
            x
->parent=y->parent;
            
        
if(!y->parent)
            root
=x;
        
else
        {
            
if(y==y->parent->left)
                y
->parent->left=x;
            
else
                y
->parent->right=x;
        }
        
        
if(y!=p)
            p
->key=y->key;
        
        
return y;
    }
    
    
return p;
}

int main(int argc,char* argv[])
{
    
int input;
    
    BST_Build();
    
    BST_Delete(
7);
    
    cout
<<"Inorder Walk:"<<endl;
    BST_Inorder_Walk(root);
    cout
<<endl;
    
    cout
<<"Preorder Walk:"<<endl;
    BST_Preorder_Walk(root);
    cout
<<endl;
    
    cout
<<"Postorder Walk:"<<endl;
    BST_Postorder_Walk(root);
    cout
<<endl;
    
    cout
<<"Min: "<<BST_Min()->key<<endl;
    cout
<<"Max: "<<BST_Max()->key<<endl;
    
    
while(1)
    {
        cin
>>input;
        
        
if(input==-1)
            
break;
        
        BST
* p;
        
if(p=BST_Search(input))
        {
            cout
<<"Parent="<<(p->parent)->key<<endl;
            
if(p->left)
                cout
<<"Left:"<<p->left->key<<endl;
            
if(p->right)
                cout
<<"Right:"<<p->right->key<<endl;
        }
        
else
        {
            cout
<<"Not found!"<<endl;
            
break;
        }
        
        
if(p=BST_Predecessor(input))
        {
            cout
<<"Predecessor:"<<p->key<<endl;
        }
        
        
if(p=BST_Successor(input))
        {
            cout
<<"Successor:"<<p->key<<endl;
        }
    }
    
    BST_Delete(root);
    
    cout
<<endl;
    system(
"pause");
    
return 0;
}

posted on 2007-08-24 12:35 Kingoal Lee's Alogrithm Study using cplusplus 閱讀(191) 評論(0)  編輯 收藏 引用

My Links

Blog Stats

常用鏈接

留言簿(1)

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 另类酷文…触手系列精品集v1小说| 久久久精品性| 免费成人黄色片| 欧美精品乱人伦久久久久久| 欧美日韩国产成人高清视频| 欧美视频中文字幕在线| 国产精品久久久久久久第一福利| 国产精品久久久久久福利一牛影视| 国产精品久久久99| 国产日韩欧美日韩| 亚洲盗摄视频| 亚洲天堂av综合网| 日韩亚洲欧美成人一区| 亚洲一区二区伦理| 久久一区国产| 日韩视频国产视频| 小处雏高清一区二区三区| 久久精品最新地址| 欧美另类一区| 国产主播在线一区| 日韩视频免费观看| 亚洲欧美美女| 欧美成人中文| 亚洲欧美视频一区二区三区| 美女视频黄 久久| 国产精品美腿一区在线看| 亚洲国产91精品在线观看| 午夜精品久久久久久久99水蜜桃| 另类图片综合电影| 亚洲视频一区二区| 久久麻豆一区二区| 噜噜噜在线观看免费视频日韩| 久久久久九九九九| 悠悠资源网久久精品| 99精品免费视频| 久久综合网色—综合色88| 麻豆国产精品一区二区三区| 亚洲毛片av在线| 久久久亚洲欧洲日产国码αv| 欧美日韩1234| 亚洲日本视频| 欧美大片免费观看| 久久精品国产精品| 国产欧美日韩一区二区三区在线观看| 日韩亚洲成人av在线| 免费成人网www| 欧美影院在线播放| 国产麻豆成人精品| 午夜精品国产| 99re6这里只有精品| 欧美激情视频一区二区三区不卡| 国产欧美日韩在线播放| 亚洲婷婷免费| 亚洲色在线视频| 欧美日韩三级在线| 国产一区二区三区在线观看免费| 亚洲影视九九影院在线观看| 亚洲国产一区二区三区a毛片| 久久久久久国产精品mv| 欧美日韩国产一区| 中文av字幕一区| 欧美一区二区| 亚洲一区二区三区在线视频| 国产精品swag| 久久精品国产亚洲精品 | 欧美亚洲视频| 欧美伊人久久久久久午夜久久久久 | 国产日韩亚洲| 欧美成人a视频| 国产精品sss| 免费在线成人| 国产精品久久久久久久免费软件| 久久久久女教师免费一区| 免费日韩av| 先锋影音国产精品| 美脚丝袜一区二区三区在线观看| 在线视频一区观看| 久久国产欧美精品| 亚洲深夜福利网站| 久久国产精品久久国产精品| 日韩天堂在线观看| 久久大逼视频| 亚洲免费在线电影| 久久综合激情| 亚洲欧美综合网| 嫩模写真一区二区三区三州| 欧美一级淫片播放口| 久久久xxx| 一区二区三区四区国产| 伊人久久大香线蕉综合热线 | 在线观看欧美亚洲| 一本色道精品久久一区二区三区| 国产一区二区三区丝袜| 在线综合亚洲| 亚洲精品久久视频| 久久成人精品一区二区三区| 亚洲一区不卡| 欧美~级网站不卡| 欧美一区二区三区在线| 欧美日韩免费观看中文| 欧美激情一区二区三区在线视频 | 国内视频精品| 亚洲免费伊人电影在线观看av| 亚洲六月丁香色婷婷综合久久| 久久国产直播| 久久久久一区二区三区四区| 国产伦精品一区二区三区免费迷| 一本色道久久综合亚洲精品不卡 | 欧美99久久| 国产一区深夜福利| 欧美一级欧美一级在线播放| 香蕉久久国产| 国产精品视频久久久| 日韩小视频在线观看专区| 亚洲久久一区| 欧美日韩dvd在线观看| 亚洲国产精品va在线看黑人动漫 | 久久久久国产精品一区| 国产精品综合不卡av| 亚洲欧美成人一区二区三区| 亚洲欧美偷拍卡通变态| 国产精品视频免费在线观看| 亚洲一区二区三区在线看| 亚洲欧美精品在线观看| 国产精品久久久久毛片软件| 亚洲一区免费看| 香蕉久久国产| 国产人成一区二区三区影院| 亚洲欧美日韩一区在线| 久久日韩精品| 亚洲人成免费| 欧美三级小说| 欧美一区二区三区四区夜夜大片| 久久精品一区| 亚洲日本欧美在线| 欧美日韩一区成人| 亚洲欧美一区二区三区在线| 久久久亚洲人| 91久久精品网| 国产精品大片| 久久久999| 亚洲全部视频| 欧美一区二区三区在线免费观看| 国产一区二区欧美日韩| 欧美aⅴ99久久黑人专区| 日韩一级片网址| 久久免费少妇高潮久久精品99| 亚洲国产va精品久久久不卡综合| 欧美日韩国产探花| 欧美一区二区视频在线观看| 亚洲国产成人午夜在线一区| 亚洲精品少妇网址| 国产精品乱码| 永久免费视频成人| 91久久精品美女高潮| 欧美国产视频在线| 亚洲一区二区三区中文字幕在线| 午夜久久久久久久久久一区二区| 国产精品一区二区久久精品| 久久久亚洲精品一区二区三区 | 欧美精品一区三区| 夜夜嗨av一区二区三区四区 | 亚洲每日在线| 久久男人资源视频| 亚洲一区二区在线免费观看视频| 国产亚洲精品美女| 欧美精品电影| 欧美在线不卡| 亚洲免费综合| 99re热这里只有精品免费视频| 久久男女视频| 欧美一区二区黄色| 亚洲天天影视| 亚洲免费av片| 亚洲国产福利在线| 国产欧美精品一区二区三区介绍 | 国产精品伊人日日| 欧美日本一区二区三区| 久久国产精品色婷婷| 在线综合亚洲欧美在线视频| 欧美激情一区二区三区全黄| 久久色中文字幕| 久久久久综合|