• <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>

            我生如山

            [導(dǎo)入]AVL Tree的一個(gè)簡單實(shí)現(xiàn)

            #ifndef _ALV_TREE_H
            #define _ALV_TREE_H
            #define Max(a,b) (((a)>(b))?(a):(b))
            #include <iostream>

            template<class T>
            class AVLTree
            {
             struct _TreeNode;
             typedef struct _TreeNode TreeNode;
             struct _TreeNode
             {
              T data;
              int height;
              TreeNode* left;
              TreeNode* right;
             };

            private:
             TreeNode *root;
            public:
             AVLTree()
             {
              this->root=NULL;
             }

             ~AVLTree()
             {
              this->MakeEmpty(this->root);
             }

             int GeiHeight()
             {
              return this->GetHeightUtil(this->root);
             }

             void Insert(T data)
             {
              this->root=this->InsertUtil(this->root,data);
             }
             
             void Delete(T data)
             {
              this->root=this->DeleteUtil(this->root,data);
             }

             void Print()
             {
              /*if(root!=NULL)
              {
               std::cout<<"The root node is: "<<root->data<<std::endl;
              }*/
              for(int level=0;;level++)
              {
               if(this->PrintUtil(this->root,level)==0)
               {
                break;
               }
               std::cout<<std::endl;
              }
             }

            private:
             TreeNode *InsertUtil(TreeNode *_root,T data)
             {
              if(_root==NULL)
              {
               _root=new TreeNode();
               _root->data=data;
               _root->left=0;
               _root->right=0;
               _root->height=0;
              }
              if(data>_root->data)
              {
               _root->right=this->InsertUtil(_root->right,data);
               if(GetHeightUtil(_root->right)-GetHeightUtil(_root->left)==2)
               {
                if(data>_root->right->data)
                {
                 _root=this->SingleRotateWithRight(_root);
                }
                else
                {
                 _root=this->DoubleRotateWithRight(_root);
                }
               }
              }
              else if(data<_root->data)
              {
               _root->left=this->InsertUtil(_root->left,data);
               if(GetHeightUtil(_root->left)-GetHeightUtil(_root->right)==2)
               {
                if(data<_root->left->data)
                {
                 _root=this->SingleRotateWithLeft(_root);
                }
                else
                {
                 _root=this->DoubleRotateWithLeft(_root);
                }
               }
              }
              _root->height=Max(GetHeightUtil(_root->left),GetHeightUtil(_root->right))+1;
              return _root;
             }

             TreeNode *DeleteUtil(TreeNode *_root,T data)
             {
              if(_root==NULL)
              {
               return _root;
              }
              else if(_root->data==data
               &&_root->left==NULL
               &&_root->right==NULL)
              {
               delete _root;
               return NULL;
              }
              else if(_root->data==data
               &&_root->left!=NULL
               &&_root->right==NULL)
              {
               TreeNode* tmpNode=_root->left;
               delete _root;
               tmpNode->height=this->RecalculateHeight(tmpNode);
               return tmpNode;
              }
              else if(_root->data==data
               &&_root->left==NULL
               &&_root->right!=NULL)
              {
               TreeNode *tmpNode=_root->right;
               delete _root;
               tmpNode->height=this->RecalculateHeight(tmpNode);
               return tmpNode;
              }
              else
              {
               if(data==_root->data)
               {
                TreeNode *tmpNode,*parentNode;
                tmpNode=_root->right->right;
                parentNode=_root->right;
                if(tmpNode!=NULL)
                {
                 while(tmpNode->right!=NULL)
                 {
                  parentNode->height-=1;
                  parentNode=tmpNode;
                  tmpNode=tmpNode->right;
                 }
                 parentNode->right=NULL;
                 _root->data=tmpNode->data;
                 delete tmpNode;
                }
                else
                {
                 _root=parentNode;
                }
                _root->height=this->RecalculateHeight(_root);
                //TreeNode *tmpNode=this->FindMax(_root->right);
                //_root->data=tmpNode->data;
                if(GetHeightUtil(_root->left)-GetHeightUtil(_root->right)==2)
                {
                 if(_root->left->left!=NULL)
                 {
                  _root=this->SingleRotateWithLeft(_root);
                 }
                 else if(_root->left->right!=NULL)
                 {
                  _root=this->DoubleRotateWithLeft(_root);
                 }
                }
               }
               else
               if(data>_root->data)
               {
                _root->right=this->DeleteUtil(_root->right,data);
                _root->height=this->RecalculateHeight(_root);
                if(GetHeightUtil(_root->left)-GetHeightUtil(_root->right)==2)
                {
                 if(_root->left->left!=NULL)
                 {
                  _root=this->SingleRotateWithLeft(_root);
                 }
                 else if(_root->left->right!=NULL)
                 {
                  _root=this->DoubleRotateWithLeft(_root);
                 }
                }
               }
               else
               {
                _root->left=this->DeleteUtil(_root->left,data);
                _root->height=this->RecalculateHeight(_root);
                if(GetHeightUtil(_root->right)-GetHeightUtil(_root->left)==2)
                {
                 if(_root->right->right!=NULL)
                 {
                  _root=this->SingleRotateWithRight(_root);
                 }
                 else if(_root->right->left!=NULL)
                 {
                  _root=this->DoubleRotateWithRight(_root);
                 }
                }
               }
              }
              //_root->height=this->RecalculateHeight(_root);
              return _root;
             }

             void MakeEmpty(TreeNode *_root)
             {
              if(_root==NULL)
              {
               return;
              }
              else
              {
               MakeEmpty(_root->left);
               MakeEmpty(_root->right);
               delete _root;
              }
             }

             int GetHeightUtil(TreeNode *_root)
             {
              /*if(_root==NULL|| (_root->left==NULL && _root->right==NULL))
              {
               return 0;
              }
              else
              {
               return 1+GetHeightUtil(_root->left)+GetHeightUtil(_root->right);
              }*/
              if(_root==NULL)
              {
               return -1;
              }
              else
              {
               return _root->height;
              }
             }

             int PrintUtil(TreeNode *node, int level)
             {
              if(node==NULL||level<0)
              {
               return 0;
              }
              else
              {
               if(level==0)
               {
                std::cout<<node->data<<" ";
                return 1;
               }
               return PrintUtil(node->left,level-1)+PrintUtil(node->right,level-1);
              }
             }

             TreeNode *SingleRotateWithLeft(TreeNode *node)
             {
              TreeNode *tmpNode=node->left;
              node->left=tmpNode->right;
              tmpNode->right=node;
              node->height=Max(GetHeightUtil(node->left),GetHeightUtil(node->right))+1;
              tmpNode->height=Max(GetHeightUtil(tmpNode->left),GetHeightUtil(tmpNode->right))+1;
              return tmpNode;
             }

             TreeNode*SingleRotateWithRight(TreeNode *node)
             {
              TreeNode *tmpNode=node->right;
              node->right=tmpNode->left;
              tmpNode->left=node;
              node->height=Max(GetHeightUtil(node->left),GetHeightUtil(node->right))+1;
              tmpNode->height=Max(GetHeightUtil(tmpNode->left),GetHeightUtil(tmpNode->right))+1;
              return tmpNode;
             }

             TreeNode* DoubleRotateWithLeft(TreeNode *node)
             {
              node->left=this->SingleRotateWithRight(node->left);
              return this->SingleRotateWithLeft(node);
             }

             TreeNode* DoubleRotateWithRight(TreeNode *node)
             {
              node->right=this->SingleRotateWithLeft(node->right);
              return this->SingleRotateWithRight(node);
             }

             TreeNode* FindMax(TreeNode *node)
             {
              //T maxData;
              while(node!=NULL&&node->right!=NULL)
              {
               node=node->right;
              }
              //maxData=node->data;
              return node;
             }

             int RecalculateHeight(TreeNode *node)
             {
              if(node==NULL)
              {
               return -1;
              }
              else
              {
               node->height=Max(RecalculateHeight(node->left),RecalculateHeight(node->right))+1;
               return node->height;
              }
             }
            };

            #endif



            若我 2008-09-28 17:30 發(fā)表評(píng)論

            文章來源:http://www.shnenglu.com/dingding/archive/2008/09/28/62997.html

            posted on 2008-09-28 17:30 悟山 閱讀(137) 評(píng)論(0)  編輯 收藏 引用

            久久中文娱乐网| 青青草原综合久久大伊人| 久久亚洲AV成人无码国产| 午夜不卡久久精品无码免费| 久久久久亚洲AV成人片| 久久国产精品免费一区| 伊人久久一区二区三区无码| 久久夜色精品国产噜噜麻豆| 国产精品久久久久影视不卡| 久久久久一本毛久久久| 亚洲中文字幕无码久久2020| 99久久伊人精品综合观看| 久久精品国产久精国产一老狼| 久久精品国产精品青草app| 久久亚洲高清综合| 久久综合给合久久狠狠狠97色 | 欧美成人免费观看久久| 久久er99热精品一区二区| 久久久免费观成人影院| www.久久精品| 无码AV波多野结衣久久| 久久精品一区二区影院 | 秋霞久久国产精品电影院| 久久久久亚洲av成人网人人软件| 欧美激情精品久久久久| 国产精品美女久久久m| 久久人妻无码中文字幕| 亚洲人成网站999久久久综合| AAA级久久久精品无码区| 久久国产亚洲精品麻豆| 亚洲中文字幕久久精品无码APP| 欧美午夜A∨大片久久| 精品欧美一区二区三区久久久| 久久久久久久综合日本亚洲 | 久久经典免费视频| 精品国产青草久久久久福利| 91久久国产视频| 久久免费小视频| 日韩亚洲欧美久久久www综合网 | 久久97精品久久久久久久不卡| 日产精品久久久一区二区|