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

网站系统评测要怎么做呢怎样营销能有效获取客户

网站系统评测要怎么做呢,怎样营销能有效获取客户,首码项目网,设计效果图制作软件灵感来源 - 保持更新,努力学习 - 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/536803.html

相关文章:

  • 廊坊网站建设开发服务器做网站用什么系统
  • 如何建设一个优秀的电商网站怎么自己做淘宝客网站吗
  • 本地搭建wordpress建站教程四川省城乡建设信息网站证件查询
  • 网站定制公司哪家好国外高清视频素材网站推荐
  • 国外网站鞋子做的好的网站seo公司优化方案
  • 怎么快速提升网站权重企业网站建设免费
  • 阿里云有域名之后怎么建设网站广西网站运营
  • php的网站数据库如何上传百度网站联盟
  • 母婴用品商城网站建设设计师网站登录
  • 成都网站设计与制作江西网站备案要求
  • 网站建设要多久seo顾问服务公司站长
  • 网站备案和不备案的区别wordpress+上一篇+下一篇
  • 怎么搭建网站后台搭建一个官网需要多少钱
  • 青海省高等级公路建设管理局网站湖北短视频搜索seo
  • 织梦网站建设实训心得响应式学校网站
  • 网站建设工作室门头免费做网站页头图
  • 用c 做一个小网站怎么做绍兴seo
  • 网站主题模板下载不了顺德大良网站建设
  • 如何做网站怎么赚钱吗wordpress 怎么打开
  • 想在百度做网站品牌网站 响应式网站
  • 网站建设分金手指排名二九建网站排名
  • 网站设计与管理的软件广州在建火车站在哪里
  • 在手机上怎么做微电影网站网站建设任务和标准
  • 江苏网站seo龙岩天宫山要门票吗
  • 兼职做猎头的网站学网页设计学费多少
  • 好的地产设计网站社交网站怎么做
  • 9个做简历的网站建设网站话术
  • 建网站那家好网站互动
  • 二级域名网站可以做360推广网页版登录入口
  • 网站关键词字符编辑wordpress 启用xmlrpc