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

网站备案哪里管百度人工智能

网站备案哪里管,百度人工智能,大连网站设计公司,学习网页设计的培训机构对称二叉树 题目题解1. 递归2. 递归 解释1. 对称2. 非对称 题目 101. 对称二叉树 给你一个二叉树的根节点 root , 检查它是否轴对称。 题解 1. 递归 # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, val0, leftNone,…

对称二叉树

    • 题目
    • 题解
      • 1. 递归
      • 2. 递归
    • 解释
      • 1. 对称
      • 2. 非对称

题目

101. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。

在这里插入图片描述

题解

1. 递归

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):def isSymmetric(self, root):""":type root: TreeNode:rtype: bool"""if not root:return Truereturn self.compare(root.left, root.right)def compare(self, left, right):#首先排除空节点的情况if left == None and right != None: return Falseelif left != None and right == None: return Falseelif left == None and right == None: return True#排除了空节点,再排除数值不相同的情况elif left.val != right.val: return False#此时就是:左右节点都不为空,且数值相同的情况#此时才做递归,做下一层的判断outside = self.compare(left.left, right.right) #左子树:左、 右子树:右inside = self.compare(left.right, right.left) #左子树:右、 右子树:左isSame = outside and inside #左子树:中、 右子树:中 (逻辑处理)return isSame

来自:代码随想录在这里插入图片描述

2. 递归

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):def isSymmetric(self, root):""":type root: TreeNode:rtype: bool"""if not root:return Truedef dfs(left, right):# 递归的终止条件是两个节点都为空# 或者两个节点中有一个为空# 或者两个节点的值不相等if not (left or right):return Trueif not (left and right):return Falseif left.val!=right.val:return False# 外侧和内侧return dfs(left.left, right.right) and dfs(left.right, right.left)return dfs(root.left, root.right)

解释

1. 对称

假设有一个二叉树如下:

    1/ \2   2/ \ / \
3  4 4  3

步骤 1: 初始调用
isSymmetric 方法首先检查根节点 1 是否为空。根节点不为空,所以调用 dfs(root.left, root.right),即检查 root.left 和 root.right 是否对称。root.left 和 root.right 都是值为 2 的节点。

步骤 2: 递归判断
对于 left 节点和 right 节点(值为 2),检查它们的左右子树是否对称。

比较 left.left 和 right.right(即 3 和 3)。它们值相等,继续递归。

比较 left.right 和 right.left(即 4 和 4)。它们值相等,继续递归。

步骤 3: 递归继续
递归深入到 left.left 和 right.right(3 和 3),以及 left.right 和 right.left(4 和 4)。它们的值相等,因此返回 True。

步骤 4: 完成判断
由于所有的对称条件都满足,最终返回 True,表示该二叉树是对称的。

2. 非对称

考虑以下不对称的二叉树:

    1/ \2   2\   \3   3

步骤 1: 初始调用
isSymmetric 方法检查根节点 1,然后调用 dfs(root.left, root.right),即检查 root.left 和 root.right 是否对称。

root.left 和 root.right 都是值为 2 的节点。

步骤 2: 递归判断
对于 left 和 right(值为 2),继续检查它们的左右子树。

比较 left.left 和 right.right,但是 left.left 是空的,right.right 是值为 3 的节点,返回 False。

步骤 3: 完成判断
由于递归过程中发现不对称,最终返回 False,表示该二叉树不是对称的。

http://www.dtcms.com/wzjs/241539.html

相关文章:

  • 网站公司排行榜前十名自媒体软文发布平台
  • 高端网站定制开发设计制作seo推广系统排名榜
  • 单位网站建设的必要性哈尔滨seo优化公司
  • 网站主题分析网络营销软件条件
  • 深圳网站设计首选刻seo根据什么具体优化
  • 视频网站用php做文案代写收费标准
  • 济南简单的网站制作线上推广宣传方式有哪些
  • 网站排版怎么做的哪个合肥seo好
  • 做百度联盟怎么才能创建多个网站友情链接系统
  • 做一网站企业管理8大系统
  • 电子商务网站设计说明书广州线下教学
  • 不同网站建设特点深圳市企业网站seo营销工具
  • 动态网站建设论文企业网站的推广阶段
  • 制作一个链接网站在线观看的seo综合查询
  • 怎么用ip做网站核心关键词
  • 三只松鼠网站怎样做流量推广app
  • 辽宁沈阳做网站好看的网站设计
  • 做58一样的网站应用宝aso优化
  • 制作人英语衡阳seo外包
  • 网站建设广告有哪些平台营销案例最新
  • 长沙装修公司排名榜秦皇岛seo招聘
  • 网站开发主要内容ip营销的概念
  • 高端网站建设文案重庆seo什么意思
  • 网站快捷按钮以什么方式做公司品牌推广方案范文
  • 焦作做网站公司比百度还强大的搜索引擎
  • 用什么做淘宝客网站好网站推广联盟
  • 可以做防盗水印的网站宁波怎么优化seo关键词
  • 检测网站是否做了301网站点击软件排名
  • 大连网站制作公司费用多少西安网站建设哪家好
  • 简历模板个人简历电子版免费可编辑太原网站优化公司