C++ 数据结构完全二叉树的判断
C++ 数据结构完全二叉树的判断
完全二叉树(Complete Binary Tree):若设二叉树的深度为h,除第h层外,其他各层(1~h-1)的节点数都达到最大个数,第h层所有的节点都连续集中在最左边,这就是完全二叉树。完全二叉树由满二叉树而引起来的。对于深度为K的,有n个节点的二叉树,当且仅当每一个节点都与深度为K的满二叉树中编号从1到n的节点一一对应时称之为完全二叉树。
注意:满二叉树一定是完全二叉树,但完全二叉树不一定是满二叉树。
完全二叉树的特点:完全二叉树的效率极高,堆是一种完全二叉树或者近似完全二叉树,像十分常用的排序算法、Dijkstra算法、Prim算法等都要用堆才能优化。
判断完全二叉树的方法:从上图我们可以看出,完全二叉树可能会出现以下情况:左子树存在,右子树不存在;左子树存在,有字数存在;左、右子树都不存在;所以我们可以利用广度优先遍历(层序遍历)将二叉树进行遍历,设置一个标志位,当遇到一个空节点时,将标志位为修改;当后面在遇到有效节点并且标志位被修改时,则该二叉树不是完全二叉树。
当该二叉树为空时、修改标志位后无有效节点时,该二叉树为完全二叉树。
代码实现:
#include<iostream> using namespace std; #include<queue> template<class T> struct TreeNode //二叉树结点 { T _value; TreeNode<T>* _left; TreeNode<T>* _right; TreeNode(const T& value) :_value(value) , _left(NULL) , _right(NULL) {} }; template<class T> bool Is_completeTree(TreeNode<T>* node) { queue<TreeNode<T>*> q; if (node != NULL) { q.push(node); TreeNode<T>* cur = NULL; bool flag = false; //设置标志位 while (!q.empty()) { cur = q.front(); q.pop(); if (cur) { if (flag) return false; q.push(cur->_left); q.push(cur->_right); } else flag = true; //修改标志位 } return true; } return true; }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
上一篇:C++实现稀疏矩阵的压缩存储实例
栏 目:C语言
下一篇:通过先序遍历和中序遍历后的序列还原二叉树(实现方法)
本文标题:C++ 数据结构完全二叉树的判断
本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/1480.html
您可能感兴趣的文章
- 04-02c语言没有round函数 round c语言
- 01-10数据结构课程设计- 解析最少换车次数的问题详解
- 01-10数据结构课程设计-用栈实现表达式求值的方法详解
- 01-10深入理解C++中常见的关键字含义
- 01-10使用C++实现全排列算法的方法详解
- 01-10c++中inline的用法分析
- 01-10用C++实现DBSCAN聚类算法
- 01-10全排列算法的非递归实现与递归实现的方法(C++)
- 01-10C++大数模板(推荐)
- 01-10浅谈C/C++中的static与extern关键字的使用详解
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 01-10delphi制作wav文件的方法
- 04-02jquery与jsp,用jquery
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10C#中split用法实例总结
- 01-11ajax实现页面的局部加载
- 01-10SublimeText编译C开发环境设置