亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

二叉搜索樹源碼分享

2020-01-26 15:32:47
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

#include <iostream>
using namespace std;

//枚舉類,前中后三種遍歷方式
enum ORDER_MODE
{
 ORDER_MODE_PREV = 0,
 ORDER_MODE_MID,
 ORDER_MODE_POST
};

//樹節點的結構體
template <class T>
struct BinaryNode
{
 T    element;
 BinaryNode  *left;
 BinaryNode  *right;

 BinaryNode(const T& theElement,
  BinaryNode *lt,
  BinaryNode *rt):
 element(theElement),
  left(lt),
  right(rt)
 {

 }
};


template <class T>
class BinarySearchTree
{
private:

 BinaryNode<T>   *m_root;

public:
 BinarySearchTree();
 BinarySearchTree(const BinarySearchTree& rhs);
 ~BinarySearchTree();

 const T& findMin() const;
 const T& findMax() const;
 bool contains(const T& x) const;
 void printTree(ORDER_MODE eOrderMode = ORDER_MODE_PREV) const;

 void makeEmpty();
 void insert(const T& x);
 void remove(const T& x);

private:
 void insert(const T& x, BinaryNode<T>* &t) ;
 void remove(const T& x, BinaryNode<T>* &t) ;
 BinaryNode<T>* findMin( BinaryNode<T>* t) const;
 BinaryNode<T>* findMax( BinaryNode<T>* t) const;
 bool contains(const T& x, const BinaryNode<T>* t) const;
 void makeEmpty(BinaryNode<T>* &t);
 void printTreeInPrev(BinaryNode<T>* t) const;
 void printTreeInMid(BinaryNode<T>* t)const;
 void printTreeInPost(BinaryNode<T>* t)const;
};

//構造方法
template <class T>
BinarySearchTree<T>::BinarySearchTree()
{
 m_root = NULL;
}

//使用另一棵二叉搜索樹的構造函數
template <class T>
BinarySearchTree<T>:: BinarySearchTree(const BinarySearchTree& rhs)
{
 m_root = rhs.m_root;
}

//析構函數,釋放內存
template <class T>
BinarySearchTree<T>:: ~BinarySearchTree()
{
 makeEmpty();
}

// 判斷x元素是否存在
template <class T>
bool  BinarySearchTree<T>::contains(const T& x) const
{
 return contains(x, m_root);
}

//遞歸調用
template <class T>
bool BinarySearchTree<T>::contains(const T& x, const BinaryNode<T>* t) const
{
 if (!t)
  return false;
 else if (x < t->element)
  return contains(x, t->left);
 else if (x > t->element)
  return contains(x, t->right);
 else
  return true;
}

// 尋找樹中的最小值
template <class T>
const T& BinarySearchTree<T>::findMin() const
{
 return findMin(m_root)->element;
}

//遞歸搜索樹中最小值
template <class T>
BinaryNode<T>* BinarySearchTree<T>::findMin( BinaryNode<T>* t) const
{
 //二叉樹的一個特點就是左子葉的值比根節點小, 右子葉的比根節點的大
 if (!t)
  return NULL;
 if (t->left == NULL)
  return t;
 else
  return findMin(t->left);
}

// 尋找樹中最大值
template <class T>
const T& BinarySearchTree<T>::findMax() const
{
 return findMax(m_root)->element;
}

//遞歸尋找樹中最大值
template <class T>
BinaryNode<T>* BinarySearchTree<T>::findMax( BinaryNode<T>* t) const
{
 //二叉樹的一個特點就是左子葉的值比根節點小, 右子葉的比根節點的大
 if (t != NULL)
  while (t->right != NULL)
   t = t->right;
 return t;
}

// 插入元素
template <class T>
void BinarySearchTree<T>:: insert(const T& x)
{
 insert(x, m_root);
}

//遞歸插入
template <class T>
void BinarySearchTree<T>::insert(const T& x, BinaryNode<T>* &t)
{
 if (t == NULL)
  t = new BinaryNode<T>(x, NULL, NULL);//注意這個指針參數是引用
 else if (x < t->element)
  insert(x, t->left);
 else if (x > t->element)
  insert(x, t->right);
 else
  ;//do nothing
}


//移除元素
template <class T>
void BinarySearchTree<T>::remove(const T& x)
{
 return remove(x, m_root);
}

//遞歸移除
template <class T>
void BinarySearchTree<T>::remove(const T& x, BinaryNode<T>* &t)
{
 if (t == NULL)
  return;
 if (x < t->element)
  remove(x, t->left);
 else if (x > t->element)
  remove (x, t->right);
 else // now ==
 {
  if (t->left != NULL &&
   t->right != NULL)//two child
  {
   t->element = findMin(t->right)->element;
   remove(t->element, t->right);
  }
  else
  {
   BinaryNode<T> *oldNode = t;
   t = (t->left != NULL) ? t->left : t->right;
   delete oldNode;
  }
 }
}

//清空二叉樹
template <class T>
void  BinarySearchTree<T>::makeEmpty()
{
 makeEmpty(m_root);
}

//遞歸清空
template <class T>
void  BinarySearchTree<T>::makeEmpty(BinaryNode<T>* &t)
{
 if (t)
 {
  makeEmpty(t->left);
  makeEmpty(t->right);
  delete t;
 }
 t = NULL;
}


// 打印二叉搜索樹
template <class T>
void BinarySearchTree<T>::printTree(ORDER_MODE eOrderMode /*= ORDER_MODE_PREV*/) const
{
 if (ORDER_MODE_PREV == eOrderMode)
  printTreeInPrev(m_root);
 else if (ORDER_MODE_MID == eOrderMode)
  printTreeInMid(m_root);
 else if (ORDER_MODE_POST == eOrderMode)
  printTreeInPost(m_root);
 else
  ;//do nothing
}

//前序打印
template <class T>
void BinarySearchTree<T>::printTreeInPrev(BinaryNode<T>* t) const
{
 if (t)
 {
  cout << t->element;
  printTreeInPrev(t->left);
  printTreeInPrev(t->right);
 }
}

//中序打印
template <class T>
void BinarySearchTree<T>::printTreeInMid(BinaryNode<T>* t) const
{
 if (t)
 {
  printTreeInPrev(t->left);
  cout << t->element;
  printTreeInPrev(t->right);
 }
}

//后序打印
template <class T>
void BinarySearchTree<T>::printTreeInPost(BinaryNode<T>* t) const
{
 if (t)
 {
  printTreeInPost(t->left);
  printTreeInPost(t->right);
  cout << t->element;
 }
}
```


測試代碼
===
```C++
#include "BinarySearchTree.h"


int main()
{
 BinarySearchTree<int> binaryTree;
 binaryTree.insert(5);
 binaryTree.insert(1);
 binaryTree.insert(2);
 binaryTree.insert(3);
 binaryTree.insert(6);
 binaryTree.insert(8);
 //測試前中后序打印
 cout <<endl<<"前序:"<<endl;
 binaryTree.printTree(ORDER_MODE_PREV);
 cout <<endl<<"中序:"<<endl;
 binaryTree.printTree(ORDER_MODE_MID);
 cout <<endl<<"后序:"<<endl;
 binaryTree.printTree(ORDER_MODE_POST);
 cout <<endl;

 //測試基本操作
 bool b = binaryTree.contains(1);
 cout<< "是否存在1:"<<b<<endl;
 int x = binaryTree.findMin();
 cout << "最小值為:"<< x <<endl;
 x = binaryTree.findMax();
 cout << "最大值為:"<< x <<endl;
 binaryTree.remove(2);

 cout << "移除元素2之后"<<endl;

 //測試前中后序打印
 cout <<endl<<"前序:"<<endl;
 binaryTree.printTree(ORDER_MODE_PREV);
 cout <<endl<<"中序:"<<endl;
 binaryTree.printTree(ORDER_MODE_MID);
 cout <<endl<<"后序:"<<endl;
 binaryTree.printTree(ORDER_MODE_POST);
 cout <<endl;

 return 0;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久综合电影一区| 亚洲一区二区免费在线| 日韩视频免费观看| 亚洲激情免费观看| 中文字幕精品一区二区精品| 色吧影院999| 国模gogo一区二区大胆私拍| 成人久久18免费网站图片| 中文字幕精品在线| 成人久久久久久久| 在线视频欧美日韩精品| 日日狠狠久久偷偷四色综合免费| 国产日韩中文字幕| 成人写真视频福利网| 午夜精品福利视频| 久久精品中文字幕| 在线精品91av| 国产精品久久久久久av下载红粉| 欧美最猛性xxxxx(亚洲精品)| 中文字幕成人精品久久不卡| 91手机视频在线观看| 欧美成人sm免费视频| 精品国产鲁一鲁一区二区张丽| 日韩欧美在线观看| 91av在线精品| 亚洲综合中文字幕在线| 精品色蜜蜜精品视频在线观看| 91av免费观看91av精品在线| 97av在线影院| 亚洲电影免费观看高清完整版在线| 96精品久久久久中文字幕| 欧美性猛交99久久久久99按摩| 伊人久久五月天| 久久不射热爱视频精品| 欧美成人国产va精品日本一级| 国产精品九九久久久久久久| 岛国视频午夜一区免费在线观看| 亚洲精品成人网| 精品久久久免费| 亚洲字幕一区二区| 国产一区二区成人| 成人做爽爽免费视频| 欧美肥婆姓交大片| 国产精品一久久香蕉国产线看观看| 91福利视频网| 亚洲老头老太hd| 日本道色综合久久影院| 日韩精品极品在线观看| 欧美日韩电影在线观看| 日韩视频在线免费观看| 97香蕉超级碰碰久久免费软件| 国产欧美日韩丝袜精品一区| 欧美激情久久久久| 国产欧美在线看| 亚洲精品自拍偷拍| 国产精品三级网站| 欧美激情综合色| 国产精品青青在线观看爽香蕉| 国产在线98福利播放视频| 成人黄色影片在线| 精品一区二区三区四区在线| 91国自产精品中文字幕亚洲| 亚洲电影在线观看| 92看片淫黄大片欧美看国产片| 日韩免费观看网站| 欧美成人免费播放| 97超级碰碰人国产在线观看| 日韩精品电影网| 欧美尤物巨大精品爽| 日韩一中文字幕| 国产经典一区二区| 日韩欧美国产免费播放| 亚洲国产成人久久| 欧美激情视频一区二区| 97超级碰碰人国产在线观看| 欧美高清视频免费观看| 亚洲男女性事视频| 97香蕉久久超级碰碰高清版| 国产成人一区二区三区| 日韩视频免费在线| 欧洲精品毛片网站| 久久久久这里只有精品| 成人国产精品久久久久久亚洲| 日韩激情第一页| 亚洲国产精品yw在线观看| 亚洲美女久久久| 欧美性猛交xxxx免费看久久久| 欧美亚洲成人免费| 91极品女神在线| 成人激情视频在线观看| 久久男人资源视频| 91久久国产综合久久91精品网站| 国产成人精品免费视频| 青青a在线精品免费观看| 日韩国产高清污视频在线观看| 精品美女国产在线| 亚洲欧美精品在线| 在线视频中文亚洲| 中文字幕亚洲二区| 久久亚洲电影天堂| 精品视频在线观看日韩| 国产九九精品视频| 91精品久久久久久久久久入口| 国产婷婷成人久久av免费高清| 亚洲免费中文字幕| 日韩欧美亚洲综合| 中文字幕亚洲国产| 91免费福利视频| 北条麻妃99精品青青久久| 久久久久久噜噜噜久久久精品| 伊人久久久久久久久久久| 亚洲电影免费观看高清完整版| 国产97在线亚洲| 97精品国产97久久久久久| 高清视频欧美一级| 国产精品h片在线播放| 国产精品 欧美在线| 亚洲国产欧美一区二区三区久久| 日韩美女视频中文字幕| 国产精品尤物福利片在线观看| 国产综合久久久久| 久久精品成人一区二区三区| 亚洲人成电影网站色…| 欧美乱大交xxxxx另类电影| 成人中文字幕在线观看| 国产xxx69麻豆国语对白| 亚洲精品av在线播放| 欧美大片在线免费观看| 国产日韩在线一区| 91精品国产免费久久久久久| 欧美一区二区三区精品电影| 国产日韩av高清| 美女撒尿一区二区三区| 美女撒尿一区二区三区| 国产精品久久久久久久7电影| 久久精品视频99| 久久久久久久久久国产| 欧美激情在线观看| 亚洲国产精品99| 成人天堂噜噜噜| 91久热免费在线视频| 国产v综合ⅴ日韩v欧美大片| 亚洲欧美日本伦理| 日韩中文字幕免费| 综合欧美国产视频二区| 亚洲天堂男人的天堂| 日韩av色在线| 国产一区二区免费| 欧美激情视频在线免费观看 欧美视频免费一| 国产一区二区美女视频| 成人黄色在线播放| 久久久久久国产免费| 亚洲一区二区三区sesese| 欧美日韩激情小视频| 亚洲精品久久久久久下一站| 精品国产乱码久久久久久虫虫漫画| 97超级碰在线看视频免费在线看| 视频在线一区二区| 欧美电影在线观看网站| 在线观看精品自拍私拍| 国产精品视频公开费视频| 亚洲日本aⅴ片在线观看香蕉| 国产精品高潮呻吟久久av无限| 国产精品人人做人人爽|