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

为什么收不到自己网站wordpress获取分类导航

为什么收不到自己网站,wordpress获取分类导航,制作网站语言,石家庄百度seo代理题目描述 给定一个二叉树,判断它是否是 平衡二叉树 思路与算法 二叉树是平衡的,如果对于每个节点,它的左子树和右子树之间的高度差最多为 1。 注意:根据上述定义,单独计算根节点的左右子树高度,然后进行…

题目描述

给定一个二叉树,判断它是否是 平衡二叉树

思路与算法

二叉树是平衡的,如果对于每个节点,它的左子树和右子树之间的高度差最多为 1。
注意:根据上述定义,单独计算根节点的左右子树高度,然后进行高度比较,是不对的。
所以应该递归地确定每个子树的高度;同时,检查每个节点的平衡条件。(两个动作)

创建一个辅助函数(我们称之为 checkBalance )

  • 如果子树是平衡的,返回其高度
  • 如果是不平衡的,返回特殊值(比如-1)
  1. base case: 如果一个节点是 None ,那么它是一个高度为 0 的空子树。这被认为是平衡的。
  2. 递归步骤
    • 对于给定的节点,递归计算其左子树和右子树的高度。
    • 检查当前节点是否平衡
      • 如果左子树或右子树不平衡(即,递归调用返回 -1),那么当前节点的子树也不平衡——立即返回 -1。
      • 如果两个子树都是平衡的,那么检查它们高度之间的差异
      • 如果差值超过 1,则以当前节点为根的树是不平衡的;返回 -1
      • 否则,当前节点的高度是其左子树和右子树高度的最大值加 1。
  3. 结果整合
    Once the helper function completes for the root
    • 如果返回 -1,则树是不平衡的
    • 否则,树是平衡的

代码

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def isBalanced(self, root: Optional[TreeNode]) -> bool:def checkBalance(node: TreeNode) -> int:# base caseif not Node:return 0leftHight = checkBalance(node.left)if leftHight == -1:return -1rightHeight = checkBalance(node.right)if rightHeight == -1:return -1if abs(leftHight - rightHeight) > 1:return -1return 1 + max(leftHight, rightHeight)return checkBalance(root) != -1

总结与反思

  1. 将明确定义的递归步骤转换为代码或伪代码
    • 书写base case(s)
      • Clearly define the simplest case(s) where the answer is known
      • 在代码中,这通常以一个 if 语句的形式出现,该语句check base case 并立即返回一个值。
    • 如果f(n)是你的函数,展示f(n)是如何依赖f(n-1)或其它实例的
    • 通过arithmetic operations, concatenation, or some form of aggregation.合并子问题结果
  2. 何时考虑使用辅助函数进行代码实现?
    • 如果你的递归解决方案需要额外的信息(例如当前深度、边界或任何其他状态),而这些信息不属于原始函数的签名,那么使用辅助函数是个好主意。当你想要将复杂性隐藏在主接口之外,或者使代码更有组织和模块化时,也可以使用辅助函数。
      • 例如,在平衡二叉树问题中,辅助函数返回子树的高度和一个标志,指示子树是否平衡。这些额外的信息在原始函数签名中并未提供,因此将递归逻辑封装在辅助函数中可以保持主函数的接口简洁。
      • 在平衡树检查中,主函数 isBalanced 只需要知道辅助函数返回的是有效高度还是特殊值(如 -1),就可以判断是否平衡
  3. 递归实现时,哪些内容可以放入辅助函数?
    • 包括核心递归算法:基本情况、递归调用、子问题结果的组合,以及在递归过程中必须保持的任何额外状态或信息。
http://www.dtcms.com/wzjs/544802.html

相关文章:

  • 时尚杂志网站设计分析陕西营销型网站建设公司
  • 很好的网站建设黑客入侵网站怎么做
  • 网站建设系统哪家便宜些淘宝 客要推广网站怎么做
  • 销售网站有哪些网站开发文档步骤应该怎么写
  • 网站制作怎么办给个网站能看的
  • 建设服装网站的意义走着瞧网站 设计
  • 什么是网络营销?它包括了哪些主要环节?抖音seo怎么做的
  • 怎么查看网站是哪个公司做的怀化网站seo
  • 做网站红色和什么搭配好重庆安全员c证查询官网
  • 甘肃做网站价格小学网站建设教程
  • 设计网站怎么设计做网站会出现哪些问题
  • 银川网站建设公司免费建站自己的网址
  • 分类网站开发郑州做网站哪家专业
  • seo网站开发注意事项WordPress商品相册幻灯片
  • 做网站需要用什么技术龙岗网站建设icxun
  • 做网站哪家好 张家口年度网站建设工作总结
  • 怎样编辑网站标题网站页面架构图
  • 镇江网站seo公司英国做电商网站有哪些
  • 驻马店网站建设wordpress网站视频播放
  • 做网站需要域名还需要什么建站系统低价建站新闻资讯
  • 工程信息网站排名苏州网页设计聚尚网络
  • 公司做网站费用网站建设邀请招标书
  • 折800网站源码传奇网页
  • 珠海cp网站建设帮客户做ppt什么的在哪个网站
  • 优秀的版式设计网站wordpress中文建站
  • 平台网站建设意见征求表新闻危机公关
  • 建设php网站国内十大网站制作公司
  • 陕西 建设工程有限公司网站手机怎么使用代理ip上网
  • 2012r2做网站建设网站后期人员薪酬
  • 网站建设延期合同书深圳品牌月饼排名