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

鲜花网站怎么做跨境电商平台有哪些分类

鲜花网站怎么做,跨境电商平台有哪些分类,同城app开发多少钱,网站规划建设与管理维护课后答案61. 题目 描述 输入一棵节点数为 n 的二叉树,判断该二叉树是否是平衡二叉树。 在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树 平衡二叉树(Balanced Binary Tree),具有以下性质&#xff1…

1. 题目

描述

输入一棵节点数为 n 的二叉树,判断该二叉树是否是平衡二叉树。

在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树

平衡二叉树(Balanced Binary Tree),具有以下性质:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。

样例解释:

样例二叉树如图,为一颗平衡二叉树

注:我们约定空树是平衡二叉树。

数据范围:n≤100,树上节点的val值满足 0 ≤n≤1000

要求:空间复杂度O(1),时间复杂度 O(n)

输入描述:

输入一棵二叉树的根节点

返回值描述:

输出一个布尔类型的值

示例1

输入:

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

返回值:

true

示例2

输入:

{}

返回值:

true

2. 解题思路

先来看平衡二叉树的性质:

平衡二叉树(Balanced Binary Tree),具有以下性质:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。

因此可以借助二叉树的高度来判断是否为平衡二叉树。整体思路为:先计算左右子树的高度,再比较左右子树的高度差(如果高度差大于1,则不是平衡二叉树)。

①对每一个节点的左右子树进行比较;②如果左子树不是平衡二叉树,就没有必要对右子树进行是否平衡的判断;③采用递归的方式对左右子树进行判断。

由于要采用递归来实现平衡二叉树的判断,因此需要验证是否满足递归的两个条件:

可以看出,求解二叉树平衡性的判断满足递归的两个条件,因此可以采用递归的方法来求解。由于平衡性的判断依赖于二叉树的高度,二叉树的高度求解参考前序文章《可视化图解算法25:二叉树的最大深度(高度)》,二叉树高度求解对应的递推公式如下:

接下来就可以依据二叉树的高度进行平衡性的判断,先求解二叉树的左右子树的高度,再判断左右子树高度差是否超过1,如果超过1则不是平衡二叉树。

如果文字描述的不太清楚,你可以参考视频的详细讲解。

  • Python编码:哔哩哔哩_bilibilihttps://www.bilibili.com/cheese/play/ep1372113

  • Java编码:数据结构笔试面试算法-Java语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Java语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ep1367352

  • Golang编码:哔哩哔哩_bilibilihttps://www.bilibili.com/cheese/play/ep1364777

3. 编码实现

核心代码如下:

/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param pRoot TreeNode类* @return bool布尔型
*/
func IsBalanced_Solution(pRoot *TreeNode) bool {// write code heretreeDepth(pRoot)return isBalanced
}var isBalanced = truefunc treeDepth(root *TreeNode) int {// 2. 递归终止条件if root == nil {return 0}// 1. 问题分解// 1.1 求解左子树的高度l := treeDepth(root.Left)// 1.2 求解右子树的高度r := treeDepth(root.Right)if math.Abs(float64(l-r)) > 1 {isBalanced = false // 不是平衡树,更改全局变量return -1          // 加一个标记-1,已经不可能是平衡树了(减少递归计算次数),直接返回}// 1.3 求解当前树的高度dep := math.Max(float64(l), float64(r)) + 1return int(dep)
}

具体完整代码你可以参考下面视频的详细讲解。

  • Python编码:哔哩哔哩_bilibilihttps://www.bilibili.com/cheese/play/ep1372113

  • Java编码:数据结构笔试面试算法-Java语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Java语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ep1367352

  • Golang编码:数据结构笔试面试算法-Go语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Go语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ep1364777

4.小结

二叉树平衡性的判断,可以通过二叉树的高度来完成,即先求解二叉树的左右子树的高度,再判断左右子树高度差是否超过1,如果超过1则不是平衡二叉树。

《数据结构与算法》深度精讲课程正式上线啦!七大核心算法模块全解析:

  ✅   链表

  ✅   二叉树

  ✅   二分查找、排序

  ✅   堆、栈、队列

  ✅   回溯算法

  ✅   哈希算法

  ✅   动态规划

无论你是备战笔试面试、提升代码效率,还是突破技术瓶颈,这套课程都将为你构建扎实的算法思维底座。🔥立即加入学习打卡,与千名开发者共同进阶!

  • Python编码实现:数据结构笔试面试算法-Python语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Python语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ss897667807

  • Java编码实现:数据结构笔试面试算法-Java语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Java语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ss161443488

  • Golang编码实现:数据结构笔试面试算法-Go语言版_哔哩哔哩_bilibili数据结构笔试面试算法-Go语言版,bilibili课堂,哔哩哔哩课堂,哔哩哔哩,Bilibili,B站,弹幕https://www.bilibili.com/cheese/play/ss63997

对于二叉树的相关算法,我们总结了一套【可视化+图解】方法,依据此方法来解决相关问题,算法变得易于理解,写出来的代码可读性高也不容易出错。具体也可以参考视频详细讲解。

今日佳句:长风破浪会有时,直挂云帆济沧海。

http://www.dtcms.com/wzjs/586961.html

相关文章:

  • 惠州营销网站建设公司招商计划书模板ppt
  • 甘肃住房和城乡建设厅网站首页浏览器怎么打开网站服务器
  • 网站背景图片怎么做建设工程机械职业技能鉴定
  • 南宁专门建网站的公司网站建设与管理教学设计
  • 网站后台登陆素材广州天华建筑设计有限公司
  • 房地产集团网站建设方案搬瓦工512m内存wordpress
  • 营销网站建设实训总结北京新网数码信息技术有限公司
  • 高端网站制销量不高的网站怎么做
  • 网站的定位分析代码优化网站排名
  • 做设计的网站大连网站制作
  • 佛山微网站推广哪家专业wordpress安装无法连接数据库
  • 企业网站管理系统 才能湖南岚鸿网站推广结束语
  • 装饰公司营销网站模板开平网站制作
  • 手机网站 制作教程wordpress做支付宝
  • ppt模板怎么做 下载网站大作设计网站
  • 网站域名在哪里申请深圳专业网站建设
  • 怎么提升网站加载速度大连百度seo
  • 网页制作企业网站作业专业企业网站建设定制
  • 如何制作网站赚钱忻州推广型网站开发
  • wordpress 登录空白百度关键词优化词精灵
  • 建设仿优酷视频网站互联网服务平台12123
  • 机械设备网站建设谷歌推广app
  • 网站制作的重要流程图淘宝店有给网站做优化am
  • 太原网站建设方案服务重庆网站备案注销
  • 京东 推广网站怎么做有必要自建网站做导购吗
  • 网站建设 长期待摊马云的网站是谁建设的
  • 中山网站开发公司咸宁网页定制
  • 深圳网站制作网络建设公司图片字体转wordpress
  • 网站后台建设用到哪些编程语言用yii框架做的网站如何搭建
  • 天津建设电工证查询网站中国国际贸易网官网