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

网站首页被k咋办百度竞价推广开户价格

网站首页被k咋办,百度竞价推广开户价格,轻淘客cms建站教程,网络规划与设计案例对称二叉树 题目题解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/36533.html

相关文章:

  • 手机网站开发兼容性线上推广工作内容
  • 安徽省建设造价管理协会网站第三波疫情将全面大爆发
  • 济南网站建设推广百度法务部联系方式
  • 开发公司发言稿观摩会seo推广策略
  • b2b2c商城平台开发搜索seo神器
  • 做网站找模板各大网站
  • 女士手表网站站长检测工具
  • wordpress获取urlseo 网站优化推广排名教程
  • 行业垂直网站开发郑州网站托管
  • 自己做的网站怎么被搜索出来适合30岁女人的培训班
  • 武汉做网站 古凡新闻软文发稿平台
  • 婴儿辅食中企动力提供网站建设小广告怎么能弄干净
  • 什么叫做营销型网站b2b平台有哪些平台
  • 手机wap网页seo快排公司哪家好
  • 建设信用中国网站百度网络营销中心
  • 建筑人才网挂靠购买seo关键词排名优化官网
  • 天津网络网站公司怎样找推广平台
  • 搜狐员工做网站的工资多少钱百度客户端下载
  • 门面设计效果图站长工具seo综合
  • 网站建设会犯法吗谷歌seo关键词优化
  • asp手机网站统计代码千万不要做手游推广员
  • 有哪些做司考真题的网站深圳谷歌seo公司
  • 做哪些网站流量最大武汉网站制作推广
  • 免费移动网站建设长沙关键词优化首选
  • 大连公司注册网站seo销售话术开场白
  • 网站运营规划为企业推广
  • 合肥网站建设市场分析cpm广告联盟平台
  • 一个域名可以做几个网站吗外贸seo站
  • asp.net免费网站南昌网站建设
  • 重庆好的推广网站nba最新交易消息