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

            若我的小家

            -編程,讀書,感悟,旅游,設計
            posts - 21, comments - 0, trackbacks - 0, articles - 0

            AVL Tree的一個簡單實現

            Posted on 2008-09-28 17:30 若我 閱讀(815) 評論(0)  編輯 收藏 引用

            #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

            久久久亚洲精品蜜桃臀| 亚洲AV无码久久精品蜜桃| 久久99精品久久久久久不卡| 亚洲精品第一综合99久久| 亚洲AV日韩AV天堂久久| 久久91这里精品国产2020| 一本色道久久综合狠狠躁| 国产午夜精品久久久久九九| 77777亚洲午夜久久多喷| 国内精品久久久久影院网站| 久久综合给久久狠狠97色| 久久免费大片| 久久综合狠狠色综合伊人| 日本强好片久久久久久AAA| 亚洲精品视频久久久| 久久精品中文字幕有码| 久久不射电影网| 久久婷婷五月综合国产尤物app| 久久久久综合中文字幕| 国产成人无码精品久久久久免费| 亚洲国产精品无码久久久不卡| 欧美亚洲日本久久精品| 国产精品99久久久久久董美香| 久久91精品国产91久久小草| 香蕉久久夜色精品升级完成| 久久人人爽人人爽人人片AV东京热| 久久免费国产精品| 日本亚洲色大成网站WWW久久| 久久播电影网| 日韩久久久久中文字幕人妻 | 99久久久精品免费观看国产| 日本WV一本一道久久香蕉| 午夜精品久久久内射近拍高清| 久久国产香蕉视频| 久久久免费观成人影院| 伊人色综合九久久天天蜜桃| 亚洲伊人久久成综合人影院 | 国产精品久久久久9999| 久久久九九有精品国产| 亚洲国产精品婷婷久久| 久久99精品国产麻豆婷婷|