当前位置: 首页 > news >正文

【数据结构】二叉树——判断是否为完全二叉树

一、思路

有完全二叉树的解释
我们想要判断二叉树是否为完全二叉树
我们可以用队列来实现
我们先将根节点入队列
再将根节点出队列,判断取出节点是否为空、

若不为空将该节点的左右节点入队列
左右节点为空也入队列

若为空则停止入队列
然后判断队列中是否有 NULL

若有则说明不是完全二叉树
若没有则说明是完全二叉树

在这里插入图片描述

在这里插入图片描述

二、代码实现

队列的代码

//判断是否为完全二叉树
bool BTComplete(BTNode* php)
{//创建队列Queue p;QueueInit(&p);//将根节点入栈QueuePush(&p, php);while (!QueueEmpty(&p)){//取出队首节点并删除QueueDateType cp = QueueFront(&p);QueuePop(&p);//判断取出节点是否为空if (cp == NULL){break;}//将左右节点入队列QueuePush(&p, cp->left);QueuePush(&p, cp->right);}//判断队列中是否有其他元素while (!QueueEmpty(&p)){//取出队首节点并删除QueueDateType cp = QueueFront(&p);QueuePop(&p);//判断节点中是否有数据if (cp != NULL){QueueDesTroy(&p);return false;}}//队列销毁QueueDesTroy(&p);return true;
}
http://www.lryc.cn/news/476247.html

相关文章:

  • FFmpeg 4.3 音视频-多路H265监控录放C++开发十. 多线程控制帧率。循环播放,QT connect 细节,
  • 近百万奖金!2024 Web3.0 创新大赛重磅来袭!
  • gRPC 一种现代、开源、高性能的远程过程调用 (RPC) 可以在任何地方运行的框架
  • cmake系列-怎么构建不同的C++程序目标文件(可执行程序、动态库、静态库)
  • 使用ffmpeg和mediamtx模拟多通道rtsp相机
  • windows系统类似于linux的nohup命令后台启动jar服务
  • 2024 Rust现代实用教程 流程控制与函数
  • stm32入门教程--USART外设 超详细!!!
  • 再探“构造函数”(2)友元and内部类
  • ffmpeg+vue2
  • 基于深度学习YOLOv10的电动二轮车目标检测、轨迹跟踪、测距算法
  • 鸿蒙ArkTS中的image组件
  • LeetCode 684.冗余连接:拓扑排序+哈希表(O(n)) 或 并查集(O(nlog n)-O(nα(n)))
  • 让空气净化器“很听话”-置入NRK3502离线语音控制芯片
  • 8个Visio最佳替代软件推荐,每一款都堪称绘图神器
  • 微服务day02
  • 使用 Logback 的最佳实践:`logback.xml` 与 `logback-spring.xml` 的区别与用法
  • NSET or MSET算法--原理解析
  • NC6 系统配置的消息渠道配置配置涉及相关的表,用户使用admin登录
  • PXC数据库性能测试对比
  • 使用AutoMySQLBackup 数据库自动备份
  • NVR批量管理软件/平台EasyNVR多个NVR同时管理支持对接阿里云、腾讯云、天翼云、亚马逊S3云存储
  • 13.React useTimeout
  • Android待机问题与内存泄露日志定位及bugreport获取分析
  • 访问控制技术原理与应用
  • 详解Rust标准库:Vec向量
  • 网络原理(初一,TCP/IP五层(或四层)模型面试问题)
  • Unity引擎材质球残留贴图引用的处理
  • Flutter鸿蒙next中封装一个列表组件
  • 层次与网络的视觉对话:树图与力引导布局的双剑合璧