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

队列+宽搜(BFS)-662.二叉树最大宽度-力扣(LeetCode)

目录

一、题目解析

1、宽度定义为最左节点和最右的非空节点之间的长度

2、类比char的存储(一个首尾相连的环,127+1!=128 = -127),虽然int可能会溢出,但是所得的差,由题目保证的32位范围内,所以结果是不会溢出的

二、算法原理

解法1:直接统计nullptr的数目(这虽然是一个错误的解法,但仍有其价值)

解法2:利用数组存储二叉树,给节点编号

编号呢有两种,可以自行选择

宽度的保存

具体过程

三、代码示例

解法2:

看到最后,如果对您有所帮助,还请点赞、收藏和关注一键三连,在未来还会继续带来优秀的内容,感谢观看,我们下期再见!


一、题目解析

1、宽度定义为最左节点和最右的非空节点之间的长度

2、类比char的存储(一个首尾相连的环,127+1!=128 = -127),虽然int可能会溢出,但是所得的差,由题目保证的32位范围内,所以结果是不会溢出的

二、算法原理

解法1:直接统计nullptr的数目(这虽然是一个错误的解法,但仍有其价值)

在遇到第一个非空节点后,开始统计nullptr的数目,在遇到下一个非空节点时,返回结果

错误之处:

存在着某个测试样式,将3000个节点左右均分,所以此时最后一层的节点树大概有2^1497个这么多

但我们在学习二叉树的时候,简单模拟是通过数组实现的,可以通过给节点编号,将节点存储在数组中,所以便有了解法2

解法2:利用数组存储二叉树,给节点编号

之前的队列都是只存储节点的指针,但我们要利用编号进行宽度计算,所以queue中或者vector模拟应存储一个pair<TreeNode*,long>的类型的数据,为什么用long呢?当然是int编号溢出了

编号呢有两种,可以自行选择

1、root为0,左孩子为2*0+1,右孩子为2*0+2,其他节点也是如此

2、root为1,左孩子为2*1,右孩子为2*1+1,其他节点也是如此

宽度的保存

结合题目和 char存储的模型,我们知道了最后的结果是有效的,但是该如何保存这个宽度呢?通过unsigned int无符号整数存储这个宽度,但是为了方便得到最终的最大值,可以初始化为1(也可以处理只有根的情况)

具体过程

参考层序遍历,只不过中间有一些空节点需要处理

在对每一层遍历时,先统计队列中的元素个数,这个个数代表该层元素个数,也代表循环次数

我们first是TreeNode*,用于判断它的左右孩子是否入队(我这里选择是nullptr不入队),second是节点的编号,用于计算宽度

在层序遍历完后,取出队列对头(左端点)和队尾(右端点),计算宽度并且与上一次结果比较,如果比上次大则更新宽度,否则不更新

三、代码示例

解法2:

class Solution {
public:int widthOfBinaryTree(TreeNode* root){queue<pair<TreeNode*,int>> qti;unsigned int ret = 1;//特殊处理只有根if(root) qti.push({root,0});//入根while(qti.size()){int num = qti.size();pair<TreeNode*,long> tmp;//int会溢出while(num--)//执行每层个数次{tmp = qti.front();qti.pop();if(tmp.first->left) qti.push({tmp.first->left,2*(tmp.second)+1});//不入空if(tmp.first->right) qti.push({tmp.first->right,2*(tmp.second)+2});//通过编号计算宽度}if(qti.size())ret = ret>qti.back().second-qti.front().second+1 ? ret : qti.back().second-qti.front().second+1;//取对头和队尾做计算}   return ret;}
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注一键三连,在未来还会继续带来优秀的内容,感谢观看,我们下期再见!
http://www.dtcms.com/a/406556.html

相关文章:

  • 【C++实战㊷】C++ 原型模式实战:从概念到高效应用
  • MCP 安全“体检” | AI 驱动的 MCP 安全扫描系统
  • 股票跟单网站开发长沙网站建设推广服务
  • 谷城网站制作wordpress给用户推送消息
  • (16)ASP.NET Core2.2 通用主机(HostBuilder)
  • .NET Core报错解决【无废话上操作】
  • python+springboot+uniapp基于微信小程序的农村事务管理与交流系统
  • React 进阶优化概念(6 个)——从能写组件到写好组件(下)| 葡萄城技术团队
  • 网站建设后期怎样维护wordpress什么模块
  • 兰州市七里河建设局网站在洪雅网站做企业招聘
  • JDK 简介及核心优点以及各种版本JDK高速下载地址(文末)
  • 妙妙题!!
  • 深圳个性化网站建设公司电话野外美食网站设计欣赏
  • React 基础核心概念(8 个)——从入门到能写业务组件(上)| 葡萄城技术团队
  • 在ARM64 Ubuntu 20.04上部署Mailu邮件系统:深度排查Docker Bridge网络通信失败问题
  • 三好街做网站的淘宝客怎么做网站管理
  • 将文件从魅族手机传输到电脑或新设备
  • 静默光伏板背后的毫秒战争:智能运维软件
  • node.js做网站开发网页制作平台排行榜
  • 3、用户认证与鉴权应该放在哪里进行?
  • iOS 混淆与 App Store 审核兼容性 避免被拒的策略与实战流程(iOS 混淆、ipa 加固、上架合规)
  • 界面设计最好的网站举例网站联盟
  • 无服务器 AI 应用:Lambda + SageMaker Endpoint 实时预测服务(技术深度版)
  • 装修公司 网站模板深圳工作服制作
  • React学习教程,从入门到精通,React 单元测试:语法知识点及使用方法详解(30)
  • Wouter 和 React Router的区别
  • 关于如何让 Vosk 正确识别中文音频,核心是 使用 Vosk 中文模型 + 确保中文音频格式符合要求
  • MySQL和PostgreSQL的数据库主键索引都是B+树吗?
  • VUE、jquery、React、Ant Design、element ui、bootstrap 前端框架的 功能总结,示例演示、使用场景介绍、完整对比总结
  • PDF格式转换、PDF编辑全功能解锁,功能图文教程