栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

二叉树最大宽度

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

二叉树最大宽度

题目:
在这里插入图片描述

思路:把每一个二叉树当作完全二叉树,这里有用到二叉树的一个性质:
对于具有n个结点的完全二叉树,如果按照从上至下从左至右的顺序对所有节点从0开始编号,则对于序号为i
的结点有: 若i>0,双亲序号:(i-1)/2;i=0,i为根结点编号,无双亲结点
若2i+1 若2i+2

我们通过层序遍历二叉树给每一个元素设置序号(序号从0开始),计算并保存每一层的宽度
宽度的计算公式:每一层最后一个元素的序号 - 每一层第一个元素的序号 + 1

将每一层的宽度存在顺序表(ArrayList)中,最后在找出最大值就行了

代码实现:

题目链接: 二叉树最大宽度

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/886429.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号