• <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 若我 閱讀(797) 評論(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

            久久久青草青青亚洲国产免观| 欧美精品乱码99久久蜜桃| 国产成人久久精品区一区二区| 国产91色综合久久免费| 久久久精品日本一区二区三区| 人妻中文久久久久| WWW婷婷AV久久久影片| 久久久久亚洲AV综合波多野结衣| 久久精品国产亚洲AV蜜臀色欲| 精品无码久久久久久午夜| 四虎久久影院| 久久国产精品99精品国产987| 久久精品视频一| 久久婷婷五月综合成人D啪| 久久A级毛片免费观看| 色综合久久夜色精品国产| 国产一久久香蕉国产线看观看| 国产精品99久久久久久宅男小说| 2020久久精品国产免费| 久久人人添人人爽添人人片牛牛| 国产精品一区二区久久精品无码| 色狠狠久久AV五月综合| 性做久久久久久久久久久| 91久久国产视频| 99久久人人爽亚洲精品美女| 日本强好片久久久久久AAA| 热久久国产欧美一区二区精品| 国产精品免费看久久久香蕉 | 久久免费精品视频| 狠狠色噜噜色狠狠狠综合久久| 久久亚洲精品无码播放| 久久精品国产黑森林| 国产高潮国产高潮久久久91 | 国产午夜精品理论片久久影视| 亚洲午夜久久久久久久久电影网 | 久久精品水蜜桃av综合天堂| 亚洲国产精品无码久久一线| 亚洲AV无码久久精品成人| 久久久久亚洲AV无码观看| 精品久久久中文字幕人妻| 伊人色综合久久天天人手人婷|