數(shù)據(jù)結(jié)構(gòu) 二叉樹的遞歸與非遞歸
更新時(shí)間:2017年05月22日 14:41:14 作者:firefox-w
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 二叉樹的遞歸與非遞歸的相關(guān)資料,需要的朋友可以參考下
數(shù)據(jù)結(jié)構(gòu) 二叉樹的遞歸與非遞歸
實(shí)例代碼:
#include <iostream> #include <queue> #include <stack> #include <assert.h> using namespace std; template<class T> struct BinaryTreeNode { BinaryTreeNode<T>* _left; BinaryTreeNode<T>* _right; T _data; BinaryTreeNode(const T& x) :_left(NULL) , _right(NULL) , _data(x) {} }; template <class T> class BinaryTree { typedef BinaryTreeNode<T> Node; public: BinaryTree() :_root(NULL) {} BinaryTree(T* a, size_t n, const T& invalid) { size_t index = 0; _root=CreateTree(a, n, invalid, index); } BinaryTree(const BinaryTree<T>& t) { _root = _Copy(t._root); } BinaryTree<T>& operator=( BinaryTree<T>& t) { swap(_root,t._root); return *this; } ~BinaryTree() { _DestroyTree(_root); } Node* CreateTree(const T* a, size_t n, const T& invalid, size_t& index) { assert(a); Node* root = NULL; if (index < n && a[index] != invalid) { root = new Node(a[index]); root->_left = CreateTree(a, n, invalid, ++index); root->_right = CreateTree(a, n, invalid, ++index); } return root; }
先序遍歷(遞歸法)
void PrevOrder() { _PrevOrder(_root); cout << endl; } //先序遍歷非遞歸 void PrevOrderNorR( ) { Node* cur = _root; stack< Node* >s; while (cur||!s.empty()) { while (cur) { cout << cur->_data << " "; s.push(cur); cur = cur->_left; } Node* top = s.top(); s.pop(); cur = top->_right; } cout << endl; }
后序遍歷
void PostOrder() { _PostOrder(_root); cout << endl; } //后序遍歷非遞歸 void PostOrderNorR() { Node* cur = _root; Node* prev = NULL; stack< Node* >s; while (cur || !s.empty()) { while (cur) { s.push(cur); cur = cur->_left; } Node* top = s.top(); if (NULL==top->_right && prev==top->_right) { cout << top->_data << " "; s.pop(); prev = top; } cur = top->_right; } cout << endl; } //中序遍歷 void InOrder() { _InOrder(_root); cout << endl; } //中序遍歷非遞歸 void InOrderNorR() { Node* cur = _root; stack< Node* >s; while (cur || !s.empty()) { while (cur) { s.push(cur); cur = cur->_left; } Node* top = s.top(); s.pop(); cout << top->_data << " "; cur = top->_right; } cout << endl; } //節(jié)點(diǎn)個(gè)數(shù) size_t Size() { return _Size(_root); } //葉子節(jié)點(diǎn)個(gè)數(shù) size_t LeafSize() { return _LeafSize(_root); } //樹的深度 size_t Depth() { return _Depth(_root); } size_t GetKLevel(size_t k) { return _GetKLevel(_root,k); } // 查找 Node* Find(size_t x) { return _Find(_root,x); } //層序遍歷 void LevelOrder() { queue<Node*> q; if (_root) { q.push(_root); } while (!q.empty()) { Node* front = q.front(); cout << front->_data << " "; q.pop(); if (front->_left) { q.push(front->_left); } if (front->_right) { q.push(front->_right); } } cout << endl; } protected: Node* _Copy(Node* root) { if (root==NULL) { return NULL; } Node* NewRoot = new Node(root->_data); NewRoot->_left = _Copy(root->_left); NewRoot->_right = _Copy(root->_right); return NewRoot; } void _DestroyTree(Node* root) { if (NULL==root) { return; } _DestroyTree(root->_left); _DestroyTree(root->_right); delete root; } void _PrevOrder(BinaryTreeNode<T>* root) { if (root) { cout << root->_data << " "; _PrevOrder(root->_left); _PrevOrder(root->_right); } } void _PostOrder(BinaryTreeNode<T>* root) { if (root) { _PostOrder(root->_left); _PostOrder(root->_right); cout << root->_data << " "; } } void _InOrder(BinaryTreeNode<T>* root) { if (root) { _InOrder(root->_left); cout << root->_data << " "; _InOrder(root->_right); } } int _Size(BinaryTreeNode<T>* root) { if (root==0) { return 0; } return _Size(root->_left) + _Size(root->_right) + 1; } int _LeafSize(BinaryTreeNode<T>* root) { if (root==NULL) { return 0; } else if (root->_left == NULL&&root->_right == NULL) { return 1; } return _LeafSize(root->_left) + _LeafSize(root->_right); } int _Depth(Node* root) { if (root==NULL) { return 0; } int left = _Depth(root->_left); int right = _Depth(root->_right); return left > right ? left + 1 : right + 1; } int _GetKLevel(Node* root, size_t k) { assert(k>0); if (root==NULL) { return 0; } else if (k==1) { return 1; } return _GetKLevel(root->_left, k - 1) + _GetKLevel(root->_right, k - 1); } Node* _Find(Node* root, const T& x) { if (root==NULL) { return NULL; } if (root->_data==x) { return root; } Node* ret = _Find(root->_left,x); if (ret != NULL) return ret; return _Find(root->_right, x); } private: BinaryTreeNode<T>* _root; };
void TestBinaryTree() { int array[10] = { 1, 2, 3, '#', '#', 4, '#', '#', 5, 6 }; BinaryTree<int> t1(array,sizeof(array)/sizeof(array[0]),'#'); BinaryTree<int>t2(t1); BinaryTree<int> t3; t3 = t2; t2.LevelOrder(); t3.LevelOrder(); t1.LevelOrder(); t1.PrevOrder(); t1.PrevOrderNorR(); t1.InOrder(); t1.InOrderNorR(); t1.PostOrder(); t1.PostOrderNorR(); cout << endl; cout << t1.Size() << endl; cout << t1.LeafSize() << endl; cout << t1.Depth() << endl; cout << t1.GetKLevel(2) << endl; cout << t1.Find(2) << endl; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
您可能感興趣的文章:
- C++ 數(shù)據(jù)結(jié)構(gòu)二叉樹(前序/中序/后序遞歸、非遞歸遍歷)
- C++使用遞歸和非遞歸算法實(shí)現(xiàn)的二叉樹葉子節(jié)點(diǎn)個(gè)數(shù)計(jì)算方法
- C++基于遞歸和非遞歸算法判定兩個(gè)二叉樹結(jié)構(gòu)是否完全相同(結(jié)構(gòu)和數(shù)據(jù)都相同)
- C++基于遞歸和非遞歸算法求二叉樹鏡像的方法
- C++非遞歸隊(duì)列實(shí)現(xiàn)二叉樹的廣度優(yōu)先遍歷
- C++非遞歸建立二叉樹實(shí)例
- C語言數(shù)據(jù)結(jié)構(gòu)之二叉樹的非遞歸后序遍歷算法
相關(guān)文章
linux shell命令快捷獲得系統(tǒng)幫助(一)[man-pages定義規(guī)范]
linux命令幫助,一般有2種,命令自身代碼里面帶有使用幫助說明,這種一般很精簡,太長了,程序自身的大小以及日常維護(hù)不方便。還有一種,就是帶有幫助文件,類似windows的chm格式文件。下面我說下這2種怎么樣查閱2015-10-10linux下實(shí)現(xiàn)ftp自動(dòng)備份shell腳本
ftp命令把遠(yuǎn)程計(jì)算機(jī)上的文件傳輸?shù)奖镜赜?jì)算機(jī)時(shí),需要和用戶交互。怎樣使交互過程自動(dòng)化呢2013-01-01Linux壓縮及解壓縮命令tar|zip|rar|xz操作方法
不管Linux還是其他操作系統(tǒng),數(shù)據(jù)的壓縮和解壓縮操作是經(jīng)常用到的,在windows平臺(tái)文件的相關(guān)操作被傻瓜化了,到了Linux平臺(tái)讓好多小伙伴感覺有點(diǎn)束手無策,本文為大家講解Linux的常用壓縮包操作,格式包含tar.gz, .tgz, .tar.bz2, .zip, .rar, .tar.xz,感興趣的朋友一起看看吧2024-02-02Shell腳本之文件批量創(chuàng)建與修改的簡單方法
有時(shí)需要將文件內(nèi)容進(jìn)行修改,如果文件數(shù)量不多可以一個(gè)一個(gè)修改,那么如果文件數(shù)量很多一個(gè)一個(gè)修改很麻煩,這篇文章主要給大家介紹了關(guān)于Shell腳本之文件批量創(chuàng)建與修改的相關(guān)資料,需要的朋友可以參考下2021-06-06