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

怎样做代刷网站长北京sem

怎样做代刷网站长,北京sem,企查查官网查企业,什么好的设计网站灵感来源 - 保持更新,努力学习 - python脚本学习 二叉树的最大深度 解题思路 这道题要求计算二叉树的最大深度,即从根节点到最远叶子节点的最长路径上的节点数。可以使用递归或迭代方法解决: 递归法(推荐)&#…

灵感来源 

- 保持更新,努力学习

- python脚本学习

二叉树的最大深度

解题思路

这道题要求计算二叉树的最大深度,即从根节点到最远叶子节点的最长路径上的节点数。可以使用递归或迭代方法解决:

  1. 递归法(推荐):

    • 每个节点的最大深度等于其左右子树深度的最大值加 1(当前节点自身)。
    • 递归终止条件:空节点的深度为 0。
      class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightdef maxDepth(root: TreeNode) -> int:if not root:return 0left_depth = maxDepth(root.left)right_depth = maxDepth(root.right)return max(left_depth, right_depth) + 1
  2. 迭代法(层序遍历):

    • 使用队列进行层序遍历(BFS),每遍历一层深度加 1。
    • 每层处理完后,队列中恰好剩下下一层的所有节点。
      from collections import dequeclass TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightdef maxDepth(root: TreeNode) -> int:if not root:return 0queue = deque([root])depth = 0while queue:# 当前层的节点数level_size = len(queue)for _ in range(level_size):node = queue.popleft()if node.left:queue.append(node.left)if node.right:queue.append(node.right)depth += 1return depth

逐行解释

递归法

class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = val       # 当前节点的值self.left = left     # 左子节点self.right = right   # 右子节点def maxDepth(root: TreeNode) -> int:# 递归终止条件:如果当前节点为空,深度为0if not root:return 0# 递归计算左子树的最大深度left_depth = maxDepth(root.left)# 递归计算右子树的最大深度right_depth = maxDepth(root.right)# 当前节点的最大深度为左右子树深度的最大值加1(包含当前节点)return max(left_depth, right_depth) + 1

迭代法

from collections import dequeclass TreeNode:def __init__(self, val=0, left=None, right=None):self.val = val       # 当前节点的值self.left = left     # 左子节点self.right = right   # 右子节点def maxDepth(root: TreeNode) -> int:# 如果根节点为空,树的深度为0if not root:return 0# 使用双端队列存储待处理的节点,初始时队列包含根节点queue = deque([root])depth = 0  # 初始化树的深度为0# 循环处理队列中的所有节点,直到队列为空while queue:# 当前层的节点数量(即队列的当前长度)level_size = len(queue)# 处理当前层的所有节点for _ in range(level_size):# 从队列左侧取出一个节点进行处理node = queue.popleft()# 如果该节点有左子节点,将左子节点加入队列if node.left:queue.append(node.left)# 如果该节点有右子节点,将右子节点加入队列if node.right:queue.append(node.right)# 处理完一层后,树的深度加1depth += 1# 返回最终计算的树的最大深度return depth
http://www.dtcms.com/wzjs/407155.html

相关文章:

  • 做平面设计都在那个网站找免费素材篮网最新消息
  • 网站的建设价格搜索引擎调词平台
  • 禹城网站制作专业的seo外包公司
  • 政府网站建设的概念西安网站建设公司
  • 旅游新闻热点seo外链怎么做能看到效果
  • 下单网站搭建网页设计论文
  • 定制衣柜哪种板材最好做博客的seo技巧
  • 个人网页制作模板田田田田田田田田站长之家seo概况查询
  • 威海哪里可以做网站torrent种子猫
  • 做门票的网站广告投放平台排名
  • 郑州专业的网站建设公司站长之家综合查询工具
  • 南宁企业建站系统软文广告范例大全
  • html设计软件厦门seo排名优化公司
  • 如何把购物网站做成非经营网站网上全网推广
  • 深圳东道建设集团网站湖南网络推广排名
  • 灵动网站建设灰色产业推广引流渠道
  • 河间做网站 申梦网络邯郸seo推广
  • 香河建设局网站bt种子搜索神器
  • 通江网站建设seo人员的相关薪资
  • 网站后台不更新如何创建微信小程序
  • 网页设计制作分段br成都网站seo费用
  • 上饶哪里做网站优化资源配置
  • 电商网站前端开发免费友情链接网站
  • 做aelogo动效有什么好的网站管理培训
  • 义乌品牌网站建设建站软件可以不通过网络建设吗
  • 福建金融公司网站建设百度官网首页网址
  • 一级a做爰片i网站最佳磁力搜索引擎
  • 武汉外贸网站建设公司百度信息流推广和搜索推广
  • 河南省建设部网站官网权威解读当前经济热点问题
  • 劳动保障局瓯海劳务市场和做网站营销技巧在线完整免费观看