圆月山庄资源网 Design By www.vgjia.com
数据结构 二叉树的递归与非递归
实例代码:
#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; } //节点个数 size_t Size() { return _Size(_root); } //叶子节点个数 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 "htmlcode">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; }感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月09日
2024年11月09日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]