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

力扣刷题(第二十一天)

灵感来源 

- 保持更新,努力学习

- 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.xdnf.cn/news/4862.html

相关文章:

  • 涨薪技术|0到1学会性能测试第56课- 堆与栈、GC回收机制
  • 如何使用测试软件 Jmeter
  • 检查当前 Docker 使用的 默认运行时(default runtime)方法
  • mysql主从同步
  • Docker组件详解:核心技术与架构分析
  • 三维底座+智能应用,重构城市治理未来
  • WorkManager与Kotlin后台任务调度指南
  • 牛客练习赛138-题解
  • leetcode 383. Ransom Note
  • 开源AI对比--dify、n8n
  • 记录一下学习kafka的使用以及思路
  • Windows远程访问Ubuntu的方法
  • zst-2001 历年真题 设计模式
  • 多视图密集对应学习:细粒度3D分割的自监督革命
  • 使用PyTorch训练马里奥强化学习代理的完整指南
  • 系统思考:短期困境与长期收益
  • Webpack基本用法学习总结
  • Vue3 + Typescript 基础进阶与实战完全指南
  • SQL进阶:如何把字段中的键值对转为JSON格式?
  • python调用国税乐企直连接口开数电票之额度管理
  • transformer 笔记 tokenizer moe
  • 科技创业园共享会议室线上预约及智能密码锁系统搭建指南
  • FPGA实战项目2———多协议通信控制器
  • 学习黑客认识数字取证与事件响应(DFIR)
  • 安科瑞ADL3000-E-A/KC三相交流电能表CE认证导轨表
  • Spring AI 系列——使用大模型对文本内容分类归纳并标签化输出
  • React 中 useMemo 和 useEffect 的区别(计算与监听方面)
  • 传统销售VS智能销售:AI如何重构商业变现逻辑
  • Microsoft 365 Copilot:为Teams在线会议带来多语言语音交流新体验
  • 【计算机网络-传输层】传输层协议-TCP核心机制与可靠性保障