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

本科毕业设计代做网站郴州网络推广公司排名

本科毕业设计代做网站,郴州网络推广公司排名,大连学网站制作,网站怎么使用模板作者介绍:10年大厂数据\经营分析经验,现任大厂数据部门负责人。 会一些的技术:数据分析、算法、SQL、大数据相关、python 欢迎加入社区:码上找工作 作者专栏每日更新: LeetCode解锁1000题: 打怪升级之旅 python数据分析…

作者介绍:10年大厂数据\经营分析经验,现任大厂数据部门负责人。
会一些的技术:数据分析、算法、SQL、大数据相关、python
欢迎加入社区:码上找工作
作者专栏每日更新:
LeetCode解锁1000题: 打怪升级之旅
python数据分析可视化:企业实战案例
python源码解读
程序员必备的数学知识与应用
备注说明:方便大家阅读,统一使用python,带必要注释,公众号 数据分析螺丝钉 一起打怪升级

题目描述

给定一个二叉树,检查它是否是镜像对称的。

输入格式
  • root:二叉树的根节点。
输出格式
  • 返回布尔值,表示树是否对称。

示例

示例 1

输入:root = [1,2,2,3,4,4,3]
输出:True

示例 2

输入:root = [1,2,2,null,3,null,3]
输出:False


方法一:递归判断

解题步骤
  1. 基本情况:如果两个节点都是 None,返回 True;一个是 None 另一个不是,返回 False
  2. 比较节点:比较当前两节点的值,如果不相等,返回 False
  3. 递归比较:递归比较左子树的左孩子和右子树的右孩子,以及左子树的右孩子和右子树的左孩子。
Python 示例
class TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = rightdef isSymmetric(root):"""判断二叉树是否对称:param root: TreeNode, 二叉树的根节点:return: bool, 是否对称"""def isMirror(left, right):if not left and not right:return Trueif not left or not right:return Falsereturn left.val == right.val and isMirror(left.left, right.right) and isMirror(left.right, right.left)return isMirror(root, root)# 示例调用
root = TreeNode(1, TreeNode(2, TreeNode(3), TreeNode(4)), TreeNode(2, TreeNode(4), TreeNode(3)))
print(isSymmetric(root))  # 输出: True
算法分析
  • 时间复杂度:(O(n)),其中 (n) 是树中节点的数量,因为需要访问树中的每一个节点。
  • 空间复杂度:(O(h)),其中 (h) 是树的高度,空间消耗来自递归的栈空间。

方法二:迭代使用队列

解题步骤
  1. 初始化队列:将根节点的两份加入队列。
  2. 迭代比较:每次从队列中取出两个节点并比较它们。
  3. 子节点入队:如果节点相同,则将它们的子节点按对称顺序加入队列。
Python 示例
from collections import dequedef isSymmetric(root):"""使用队列迭代判断二叉树是否对称:param root: TreeNode, 二叉树的根节点:return: bool, 是否对称"""queue = deque([root, root])while queue:t1, t2 = queue.popleft(), queue.popleft()if not t1 and not t2:continueif not t1 or not t2 or t1.val != t2.val:return Falsequeue.append(t1.left)queue.append(t2.right)queue.append(t1.right)queue.append(t2.left)return True# 示例调用
root = TreeNode(1, TreeNode(2, None, TreeNode(3)), TreeNode(2, None, TreeNode(3)))
print(isSymmetric(root))  # 输出: False
算法分析
  • 时间复杂度:(O(n)),因为需要访问每个节点。
  • 空间复杂度:(O(n)),在最坏的情况下,队列中需要存储所有节点。

方法三:使用栈进行迭代

解题步骤
  1. 使用栈:将根节点的两份压入栈中。
  2. 迭代比较:从栈中弹出两个节点并进行比较。
  3. 子节点压栈:如果节点相同,则将它们的子节点按对称顺序压入栈中。
Python 示例
def isSymmetric(root):"""使用栈迭代判断二叉树是否对称:param root: TreeNode, 二叉树的根节点:return: bool, 是否对称"""if not root:return Truestack = [(root.left, root.right)]while stack:left, right = stack.pop()if not left and not right:continueif not left or not right or left.val != right.val:return Falsestack.append((left.left, right.right))stack.append((left.right, right.left))return True# 示例调用
root = TreeNode(1, TreeNode(2, None, TreeNode(3)), TreeNode(2, None, TreeNode(3)))
print(isSymmetric(root))  # 输出: False
算法分析
  • 时间复杂度:(O(n)),需要访问每个节点。
  • 空间复杂度:(O(n)),在最坏的情况下,栈中需要存储所有节点。

不同算法的优劣势对比

特征方法一:递归方法二:迭代队列方法三:迭代栈
时间复杂度(O(n))(O(n))(O(n))
空间复杂度(O(h))(O(n))(O(n))
优势易于实现不使用递归不使用递归
劣势可能栈溢出空间开销大空间开销大

应用示例

这些方法可以用于计算机视觉中对象的对称性检测,软件测试中的树结构数据验证,或者在机器学习数据预处理中检查数据的对称性。

http://www.khdw.cn/news/39572.html

相关文章:

  • 18互联网站做网站程序seo关键词是什么意思
  • php网站安装好后后台无法登陆提示是500是怎么回事?百度小说风云榜
  • 网站head蓝色色调免费psd背景青岛做网络推广的公司有哪些
  • 郑州网站优化公司电话西安网站建设网络推广
  • 怎么找到仿牌外贸出口公司的网站代写文章质量高的平台
  • 自己做抽奖网站违法网站seo策划方案实例
  • 专门做颜料的网站seo爱站网
  • 工程招标信息在哪看汕头seo外包公司
  • 邯郸快讯网络科技有限公司老铁seo外链工具
  • 网站优化怎么做 百度文库站长之家论坛
  • p2p系统网站开发百度网盘下载
  • 资源付费网站制作关键词检测
  • 九龙坡网站建设多少钱1个百度指数代表多少搜索
  • 微信网站是什么意思小程序推广
  • 网站空间和域名好用的搜索引擎
  • 常州住房和城乡建设局网站手机建站教程
  • 幼儿园网站建设7个基本流程seo好找工作吗
  • 北京高端网站制作新东方小吃培训价格表
  • python做爬虫和做网站免费代码网站
  • 网站定时数据切换怎么做的鹤岗网站seo
  • 株洲做网站的网站seo运营
  • 站群系统有哪些网站推广seo招聘
  • 关键词优化难易浙江seo博客
  • 申请建设网站经费申请真正免费的网站建站平台有哪些
  • 做网站需要搭建服务器么杭州网站seo优化
  • 深圳产品外观设计公司东莞网站推广及优化
  • 天津餐饮网站建设百度极速版客服电话
  • 网站设计的流程简答题seo网络营销技术
  • 海外宣传推广实施方案优化 保证排名
  • 医生可以自己做网站吗长沙网络营销外包哪家好