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

若我的小家

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

AVL Tree的一個簡單實現

Posted on 2008-09-28 17:30 若我 閱讀(820) 評論(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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产日韩三区| 亚洲国产天堂久久国产91| 欧美一级大片在线观看| 国产精品国产三级欧美二区| 欧美日本三级| 性久久久久久久久| 麻豆av一区二区三区| 91久久香蕉国产日韩欧美9色| 欧美日韩成人| 午夜精品久久久久久久久久久久久| 久久久亚洲国产美女国产盗摄| 亚洲精品久久久久久久久久久久久 | 国产午夜亚洲精品羞羞网站| 国户精品久久久久久久久久久不卡| 欧美大片在线观看| 亚洲欧美日本伦理| 亚洲国产精品视频| 欧美一级在线播放| 亚洲美女视频| 黄网站色欧美视频| 国产精品欧美一区喷水| 麻豆精品精品国产自在97香蕉| 亚洲视频导航| 91久久精品国产91久久性色| 一区二区三区蜜桃网| 久久综合九色综合欧美就去吻| 亚洲图片在线| 亚洲人体1000| 影音先锋欧美精品| 国产欧美日韩视频在线观看| 91久久精品一区| 国模精品一区二区三区| 欧美色欧美亚洲另类七区| 久久久噜噜噜久久人人看| 亚洲一区二区视频在线观看| 久久久久久久999精品视频| 亚洲无限av看| 亚洲精品视频免费在线观看| 久久爱另类一区二区小说| 午夜精彩视频在线观看不卡| 久热精品在线视频| 欧美在线免费一级片| 亚洲国产精品va在线看黑人动漫| 欧美在线视频在线播放完整版免费观看| 91久久精品日日躁夜夜躁欧美 | 国精品一区二区| 国产精品大片免费观看| 欧美日韩播放| 欧美视频在线观看一区| 欧美日韩一区二区视频在线 | 亚洲国产精品久久91精品| 国产欧美一区二区三区沐欲| 99热在这里有精品免费| 一二美女精品欧洲| 在线午夜精品| 亚洲免费一在线| 欧美在线视频一区| 久久久久免费视频| 麻豆国产精品777777在线 | 久久另类ts人妖一区二区| 久久精品国产亚洲5555| 久久福利精品| 猫咪成人在线观看| 欧美激情一级片一区二区| 亚洲大片在线| 日韩网站在线| 亚洲欧美综合网| 欧美中文字幕在线播放| 久久九九精品| 欧美精品一区视频| 国产精品第十页| 韩国一区电影| 日韩视频在线永久播放| 中文日韩欧美| 久久久夜夜夜| 亚洲黄色片网站| 中文亚洲字幕| 久久精品国产亚洲高清剧情介绍| 老司机亚洲精品| 欧美三区在线观看| 黄色另类av| 亚洲男人的天堂在线| 久久久精品国产免大香伊| 欧美~级网站不卡| 99re热这里只有精品视频| 午夜精品免费在线| 欧美激情精品久久久六区热门| 国产精品日韩欧美综合| 亚洲四色影视在线观看| 校园春色综合网| 午夜亚洲福利| 午夜精品视频在线观看| 欧美在线日韩在线| 亚洲国产精品一区二区www在线 | 久久久国产91| 亚洲黄色免费电影| 欧美一区二区三区免费在线看 | 欧美日韩精品一区视频| 国产精品久久久| 亚洲精品国产精品乱码不99 | 日韩一二三区视频| 久久精品国产77777蜜臀| 欧美激情一区二区三区在线视频观看| 国产精自产拍久久久久久| 亚洲国产精品尤物yw在线观看 | 国产精品尤物| 中文高清一区| 91久久精品日日躁夜夜躁国产| 久久riav二区三区| 国产精品福利在线| 91久久线看在观草草青青| 久久久久久尹人网香蕉| 亚洲综合导航| 国产精品盗摄久久久| 亚洲免费av片| 亚洲国产99| 美女被久久久| 亚洲成人影音| 麻豆91精品| 久久综合色天天久久综合图片| 国产午夜亚洲精品理论片色戒| 亚洲欧美一区二区三区在线| 欧美xxx在线观看| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲国产综合在线| 欧美ab在线视频| 亚洲国产精品一区二区第一页| 欧美黄色一区| 久久夜色精品国产噜噜av| 国模私拍一区二区三区| 久久精品国产99国产精品| 亚洲欧美伊人| 国语自产偷拍精品视频偷| 久久久99国产精品免费| 欧美在线观看一区| 欲色影视综合吧| 欧美国产在线观看| 欧美成人激情在线| 亚洲精品美女免费| 亚洲精品一区二区三区av| 欧美日韩精品久久| 亚洲欧美精品在线| 午夜在线一区| 亚洲第一黄网| 亚洲高清不卡在线| 欧美精品videossex性护士| 99香蕉国产精品偷在线观看| 免费精品视频| 亚洲欧美激情诱惑| 久久久精品性| 一本色道久久综合精品竹菊| 欧美激情综合网| 欧美一区二区三区在线视频 | 欧美一区1区三区3区公司| 亚洲在线1234| 亚洲高清在线精品| 亚洲美女精品成人在线视频| 日韩午夜电影| 欧美一级淫片aaaaaaa视频| 在线精品观看| 国产精品99久久久久久久vr | 亚洲午夜久久久久久久久电影院| 一区二区三区毛片| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产va精品久久久不卡综合| 欧美日韩午夜| 蜜桃精品久久久久久久免费影院| 欧美日韩1区| 久久天堂av综合合色| 欧美日本在线观看| 久久只精品国产| 欧美系列精品| 亚洲高清免费| 国产一区二区三区日韩| 亚洲三级电影全部在线观看高清| 国产亚洲一区二区三区在线观看| 日韩系列欧美系列| 亚洲电影在线播放| 午夜精品久久久久久久99樱桃| 亚洲精品综合| 久久久久.com| 久久精品国产精品| 国产精品爽爽ⅴa在线观看| 亚洲黄色天堂| 亚洲乱码国产乱码精品精可以看 | 欧美成人a视频| 欧美日韩综合一区| 欧美大尺度在线观看| 国产伦一区二区三区色一情| 欧美在线观看天堂一区二区三区| 欧美一级播放| 国产精品久久久久久久第一福利| 91久久午夜| 91久久国产精品91久久性色| 欧美性猛交xxxx乱大交蜜桃| 另类尿喷潮videofree| 久久综合九色九九| 国产曰批免费观看久久久| 亚洲欧美日韩直播| 欧美一区二区三区播放老司机|