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

哪一个景区网站做的最成熟晨阳seo

哪一个景区网站做的最成熟,晨阳seo,wordpress 插件 简码 使用,深圳软件外包公司排名一、题目解析 题目描述 给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的: 1/ \2 2/ \ / \ 3 4 4 3而 [1,2,2,null,3,null,3] 则不是镜像对称的: 1/ \2 2\ \3 3问题本质 判断一棵二叉…

一、题目解析

题目描述

给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的:

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

[1,2,2,null,3,null,3] 则不是镜像对称的:

    1/ \2   2\   \3    3

问题本质

判断一棵二叉树是否镜像对称,等价于判断其左子树和右子树是否互为镜像。具体来说,需要满足以下条件:

  • 根节点的值相同
  • 每个树的左子树与另一个树的右子树镜像对称

二、双端队列解法思路

核心思想

使用双端队列(Deque)同时存储待比较的节点对,通过队列两端的操作,确保每次取出的节点对是需要比较的镜像节点。具体步骤如下:

  1. 将根节点的左右子节点分别从队列的前端和后端入队
  2. 每次循环从队列两端各取出一个节点进行比较
  3. 若两节点均为空,继续循环
  4. 若两节点中只有一个为空或值不相等,返回 false
  5. 若两节点均非空且值相等,将它们的子节点按镜像关系入队:
    • 左子树的左节点与右子树的右节点入队
    • 左子树的右节点与右子树的左节点入队

代码实现

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public boolean isSymmetric(TreeNode root) {Deque<TreeNode> cur = new LinkedList<>();if (root == null) {return true;}TreeNode tempLeft = root.left;TreeNode tempRight = root.right;cur.offerFirst(tempLeft);cur.offerLast(tempRight);while (!cur.isEmpty()) {tempLeft = cur.pollFirst();tempRight = cur.pollLast();if (tempLeft == null && tempRight == null) {continue;}if (tempLeft == null || tempRight == null || tempLeft.val != tempRight.val) {return false;}cur.offerFirst(tempLeft.left);cur.offerFirst(tempLeft.right);cur.offerLast(tempRight.right);cur.offerLast(tempRight.left);}return true;}
}

三、代码详细解释

初始化与边界处理

Deque<TreeNode> cur = new LinkedList<>();
if (root == null) {return true;
}
TreeNode tempLeft = root.left;
TreeNode tempRight = root.right;
cur.offerFirst(tempLeft);
cur.offerLast(tempRight);
  • 创建双端队列 cur 用于存储待比较的节点对
  • 若根节点为空,直接返回 true(空树视为对称)
  • 将根节点的左右子节点分别从队列的前端和后端入队

主循环处理

while (!cur.isEmpty()) {tempLeft = cur.pollFirst();tempRight = cur.pollLast();if (tempLeft == null && tempRight == null) {continue;}if (tempLeft == null || tempRight == null || tempLeft.val != tempRight.val) {return false;}// 处理子节点
}
  • 每次循环从队列前端和后端各取出一个节点
  • 若两节点均为空,跳过当前循环
  • 若两节点中只有一个为空或值不相等,说明不对称,返回 false

子节点处理

cur.offerFirst(tempLeft.left);
cur.offerFirst(tempLeft.right);
cur.offerLast(tempRight.right);
cur.offerLast(tempRight.left);
  • 将左子树的左节点和右节点依次从队列前端入队
  • 将右子树的右节点和左节点依次从队列后端入队
  • 这样确保了下一次循环时,左子树的左节点会与右子树的右节点比较,左子树的右节点会与右子树的左节点比较

四、算法示例演示

以对称二叉树 [1,2,2,3,4,4,3] 为例,展示队列的变化过程:

初始状态

队列: [2, 2]

第一次循环

  • 取出 22
  • 值相等,处理子节点:
    • 左子树的左节点 3 入队首
    • 左子树的右节点 4 入队首
    • 右子树的右节点 3 入队尾
    • 右子树的左节点 4 入队尾
队列: [3, 4, 4, 3]

第二次循环

  • 取出 33
  • 值相等,无子节点,队列变为 [4, 4]

第三次循环

  • 取出 44
  • 值相等,无子节点,队列为空
  • 返回 true

五、复杂度分析

  • 时间复杂度:O(n),每个节点仅被访问一次
  • 空间复杂度:O(h),h为树的高度,最坏情况下为O(n)

六、双端队列的优势

使用双端队列的关键在于能够同时维护两个方向的节点对,通过以下操作实现镜像比较:

  • offerFirst()pollFirst() 处理左子树节点
  • offerLast()pollLast() 处理右子树节点
  • 这种设计使得每次取出的节点对恰好是需要比较的镜像节点,避免了递归或单队列方法中的额外处理逻辑

七、总结

双端队列解法通过巧妙的入队和出队策略,将镜像比较的逻辑转化为队列两端的操作,既保持了迭代方法的优势(避免栈溢出),又直观地实现了节点对的比较。理解这种解法的关键在于把握队列操作与镜像关系的对应:

  • 左子树的左节点 → 队列前端
  • 左子树的右节点 → 队列前端
  • 右子树的右节点 → 队列后端
  • 右子树的左节点 → 队列后端

这种对称性的设计使得代码简洁高效,是解决对称二叉树问题的一种优雅方式。

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

相关文章:

  • 淮北网站建设百度seo网站
  • 企业融资计划书唐山seo排名优化
  • 广东网站制作我想在百度上发布广告怎么发
  • 吉林省建设安全信息网站网络营销岗位
  • 办一个网站要多少钱在哪里找专业推广团队
  • gate网站合约怎么做空营销方式方案案例
  • golang 做网站搜索引擎广告的优缺点
  • 哪些网站自己做宣传免费制作详情页的网站
  • minecraft做图网站济南seo网站排名关键词优化
  • php做网站如何配置域名的福建seo学校
  • 公司自己建立网站seo中心
  • 网站建设w亿玛酷1负责爱站网关键词挖掘查询工具
  • 宁夏百度网站怎么做互联网哪个行业前景好
  • 做微信公众号网站今天刚刚发生的重大新闻
  • 安徽人防工程建设网站百度站长之家工具
  • 网站建设维护费会计科目sem竞价
  • 公司做网站比较好网站优化北京seo
  • 东莞建网站服务百度搜索推广方案
  • 购物平台网站建设流程深圳seo网站优化公司
  • 如何查看网站架构百度导航最新版本下载安装
  • 光谷网站建设直播回放老卡怎么回事
  • 怎么自己网站搜不到了建站系统哪个比较好
  • asp做网站优点爱站网关键词查询工具
  • ASP.NET实用网站开发 课后答案百度知道网页入口
  • 做模块高考题的网站自动点击器永久免费版
  • 公司网站打开的时候显示该网站多个子域名中病毒运营主要做什么工作
  • 160 作者 网站建设国内最新新闻大事
  • 天天向上做图网站企业管理培训课程报名
  • 网站建设和空间企业营销培训课程
  • 北京做网站公司哪家好河北网站seo