python二叉树最小深度是什么
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这期内容当中小编将会给大家带来有关python二叉树最小深度是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。求二叉树最小深度给定一个二叉树,找出其最小深度。最小
千家信息网最后更新 2025年01月31日python二叉树最小深度是什么
这期内容当中小编将会给大家带来有关python二叉树最小深度是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
求二叉树最小深度
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
返回它的最小深度 2.
补全下面代码:
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
def minDepth(self, root):
"""
:type root: TreeNode
:rtype: int
"""
2 分析
分析过程的开始,我们先看一个错误的求解,并说明为什么它是错误的:
class Solution(object):
def minDepth(self, root):
"""
:type root: TreeNode
:rtype: int
"""
if not root:
return 0
if not root.left and not root.right:
return 1
return 1 + min(self.minDepth(root.left),self.minDepth(root.right))
考虑下面二叉树:
使用以上代码返回最小深度为 1,其实最小深度为 2,因为最小深度的定义为:从根节点到最近叶子节点的最短路径上的节点数量。
为什么上面的解有问题呢?
原因在于递归基选取有问题,只考虑了下面两种情况:
二叉树为 None 二叉树只有一个节点
递归基未考虑下面两种情况,所以导致出错:
3
正确的求解,需要把上面遗漏的两种递归基考虑进去:
# 递归基的下面两种情况必须考虑进去:
if not root.left:
return 1 + self.minDepth(root.right)
if not root.right:
return 1 + self.minDepth(root.left)
正确的完整代码如下:
class Solution(object):
def minDepth(self, root):
if not root:
return 0
if not root.left and not root.right:
return 1
# 递归基的下面两种情况必须考虑进去:
if not root.left:
return 1 + self.minDepth(root.right)
if not root.right:
return 1 + self.minDepth(root.left)
return 1 + min(self.minDepth(root.left),self.minDepth(root.right))
上述就是小编为大家分享的python二叉树最小深度是什么了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
节点
最小
深度
递归
情况
分析
代码
叶子
内容
数量
错误
问题
专业
中小
内容丰富
原因
只有
就是
文章
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库安全数据集
成都服务器报价
医疗软件开发的业务流程
ps5哪个服务器比较便宜
怎么控制vb数据库
我的世界离线服务器1.12.2
网络技术产生的伦理困惑
增城高速荔城服务器西区钻福专柜
合伙人互助软件开发
oracle数据库快捷键
21世纪以来的网络技术
嵌入式linux服务器
文档存储服务器
海曙专业软件开发项目管理
网络安全进校园 活动信息
金蝶显示服务器内部服务没有响应
工业网络安全的宣传
网络安全态势感知系统怎么用
软件开发供应商自评表格
流程审批软件开发
个人虚拟机服务器端口在哪里
软件开发外包项目网
宁波运营网络技术哪家好
前景网络技术有限公司
网页服务器ip多少
淮北机械专业软件开发平台
服务器共享打印机无法访问
计算机网络技术好难啊6
数据库图片放在哪里了
河北工业大学网络安全学院
- 上一篇
jQuery+ajax实现文件上传进度条
这篇文章主要介绍"jQuery+ajax实现文件上传进度条",在日常操作中,相信很多人在jQuery+ajax实现文件上传进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家
- 下一篇
Linux运行lsb_release -a命令报错-bash: lsb_release: command not found的原因和解决方法
本篇内容介绍了"Linux运行lsb_release -a命令报错-bash: lsb_release: command not found的原因和解决方法"的有关知识,在实际案例的操作过程中,不少人