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

建设局网站港府名都野望王绩

建设局网站港府名都,野望王绩,做网站怎么收费的,软件开发平台建设目录 1 问题描述 1.1 示例1 1.2 示例2 1.3 示例3 2 解题思路 3 代码实现 4 代码解析 4.1 定义队列,初始化根节点 4.2 层序遍历,处理每个节点 4.3 处理空节点 4.4 处理非空节点 5 总结 1 问题描述 给定一个二叉树,确定他是否是一…

目录

1 问题描述

1.1 示例1

1.2 示例2

1.3 示例3

2 解题思路 

3 代码实现

4 代码解析

4.1 定义队列,初始化根节点

4.2 层序遍历,处理每个节点

4.3 处理空节点

4.4 处理非空节点

5 总结


1 问题描述

给定一个二叉树,确定他是否是一个完全二叉树。

完全二叉树的定义:若二叉树的深度为 h,除第 h 层外,其它各层的结点数都达到最大个数,第 h 层所有的叶子结点都连续集中在最左边,这就是完全二叉树。(第 h 层可能包含 [1~2h] 个节点)

数据范围:节点数满足 1≤n≤100 1≤n≤100 

样例图1:

样例图2:

样例图3:

1.1 示例1

输入:

{1,2,3,4,5,6}

返回值:

true

1.2 示例2

输入:

{1,2,3,4,5,6,7}

返回值:

true

1.3 示例3

输入:

{1,2,3,4,5,#,6}

返回值:

false

2 解题思路 

采用层序遍历(BFS)方式,通过队列 queue<TreeNode*> 进行逐层扫描。首先将根节点入队,然后依次出队检查其左右子节点。关键在于一个布尔变量 mustBeLeaf,用于标识是否已经遇到 nullptr,即是否应该只允许叶子节点(空节点)出现。当 nullptr 出现后,若后续仍有非空节点,则说明该树不是完全二叉树,返回 false;否则,遍历结束返回 true。这样保证了若某层的节点不满,则该层之后不能再有非空节点,从而正确判断完全二叉树的性质。

3 代码实现

    bool isCompleteTree(TreeNode* root) {// write code hereif (root == nullptr) return true;queue<TreeNode*> q;q.push(root);bool mustBeLeaf = false;while (!q.empty()) {TreeNode* node = q.front();q.pop();if (mustBeLeaf){if (node != nullptr) return false;}else {if (node == nullptr){mustBeLeaf = true;}else {q.push(node->left);q.push(node->right);}}}return true;}

4 代码解析

4.1 定义队列,初始化根节点

if (root == nullptr) return true;
queue<TreeNode*> q;
q.push(root);
bool mustBeLeaf = false;

首先,代码检查根节点是否为空,若为空,则直接返回 true,因为空树是完全二叉树。然后,定义一个队列 q,用于进行层序遍历(BFS),并将根节点 root 入队。变量 mustBeLeaf 用于标记是否遇到了空节点,一旦为 true,后续所有节点必须为空,否则就不是完全二叉树。

4.2 层序遍历,处理每个节点

while (!q.empty()) {TreeNode* node = q.front();q.pop();

使用 while 循环进行层序遍历,每次从队列 q 中取出队首节点 node。如果 q 为空,说明遍历完成,跳出循环。

4.3 处理空节点

    if (mustBeLeaf){if (node != nullptr) return false;}

如果 mustBeLeaftrue,说明之前已经遇到了空节点,那么所有后续节点都必须为空。如果当前节点 node 不是空节点,则说明二叉树不是完全二叉树,直接返回 false

4.4 处理非空节点

    else {if (node == nullptr){mustBeLeaf = true;}else {q.push(node->left);q.push(node->right);}}

如果 mustBeLeaf 仍为 false,则说明当前节点还可以是非空的。如果当前节点 nodenullptr,则将 mustBeLeaf 设为 true,意味着之后所有节点必须为空。如果当前节点 node 不是 nullptr,则继续将 node->leftnode->right 依次入队,即继续层序遍历子节点。

5 总结

通过队列依次遍历每个节点,并使用布尔变量 mustBeLeaf 来标记是否已经遇到空节点,确保一旦出现 nullptr,后续所有节点都必须为空,否则返回 false。该方法能有效检测是否存在不连续的叶子节点,从而正确判断完全二叉树的性质。整个算法的时间复杂度为 O(n),空间复杂度为 O(n),适用于 n ≤ 100 的数据范围,能够高效解决问题。

http://www.dtcms.com/a/436153.html

相关文章:

  • 自己的网站服务器可以免费做推广的网站
  • 四川省建设工程造价信息网站公司实验室设计
  • 《基层建设》官方网站陈村网站设计
  • 吃透大数据算法-数据压缩算法Run Length Encoding(RLE)
  • 宜兴建设公司网站网页设计师联盟网站怎么
  • 上海网站建设seodian莱芜区都市网莱芜杂谈
  • 网站注册搜索引擎的目的是企业网络维护一般多少钱
  • 网站发布平台南宁伯才网络建站如何
  • 广安网站建设推荐h5是什么意思游戏
  • 分类信息的网站如何推广做建筑材料哪个网站好一点
  • 就业指导中心网站建设总结天津网站建设制作开发公司
  • 西安网站注册2015百度竞价单页面网站模板源码设计
  • 搜索网站模板常州 网站建设
  • com.mysql.cj.jdbc.Driver 解析
  • 做网站撘框架南沙网站开发
  • Qt开发学习——QtCreator深度介绍/程序运行/开发规范/对象树
  • [创业之路-661]:相对于采集狩猎社会,农业社会新增学科和新增职业
  • 有做兼职赚钱的网站吗网站站长英文
  • Javascript/ES6+/Typescript重点内容篇——手撕
  • 网站建设和优化那本书好seo引擎优化是做什么的
  • 【c语言文件操作】
  • SPI Flash基础知识点 (腾讯元宝版本)
  • 天津的网站建设成都网站建设 木木科技
  • 苏州浒关做网站哪里有网站推广公司
  • 怎么买域名自己做网站常州医院网站建设
  • 网站收录平台青岛优化网站多少钱
  • 做静态网站多少钱与恶魔做交易的网站
  • 哈德网站建设建设短视频网站
  • 做exo小说的网站互联网创业项目整合网站
  • 国外网站 模板外贸网站设计公司