算法(TS):对称二叉树

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

示例一

示例一是对称二叉树

示例二

示例二不是对称二叉树

解法

如果二叉树的左右两棵树呈镜像对称,那么这个二叉树是对称二叉树。两个树互为镜像,需要满足下面的要求:

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

解法一

用两个指针 v、u 分别指向左右子树的根,比较 v、u的值是否相等,不相等则不是对称二叉树,相等则将 v 移动到 v.left,将 u 移动到u.right,比较他们指向的节点是否相等,还要将 v 移动到 v.right,将 u 移动到u.left,比较他们指向的节点是否相等。任意一边不相等则说明不是对称二叉树。

递归实现:如下

ts 复制代码
/**
 * Definition for a binary tree node.
 * class TreeNode {
 *     val: number
 *     left: TreeNode | null
 *     right: TreeNode | null
 *     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
 *         this.val = (val===undefined ? 0 : val)
 *         this.left = (left===undefined ? null : left)
 *         this.right = (right===undefined ? null : right)
 *     }
 * }
 */

function isSymmetric(root: TreeNode | null): boolean {
    const check = (v: TreeNode | null,u: TreeNode | null):boolean => {
        if (!v && !u) return true
        if (!v || !u) return false
        if (v.val !== u.val) return false

        return check(u.left,v.right) && check(u.right,v.left)
    }

    return check(root.left,root.right)
};

时间复杂度O(n),空间复杂度O(n)

解法二

迭代实现。首先我们引入一个队列,这是把递归程序改写成迭代程序的常用方法。将需要比较是否相同的两个节点(即v.right和u.left、v.left和u.left)连续放在队列中,入队列的时候一次入两个,出队列的时候也一次出两个。如果出队列的节点值不相同则说明不是对称二叉树。

ts 复制代码
/**
 * Definition for a binary tree node.
 * class TreeNode {
 *     val: number
 *     left: TreeNode | null
 *     right: TreeNode | null
 *     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
 *         this.val = (val===undefined ? 0 : val)
 *         this.left = (left===undefined ? null : left)
 *         this.right = (right===undefined ? null : right)
 *     }
 * }
 */

function isSymmetric(root: TreeNode | null): boolean {
    if (!root) return true
    const stack = [root,root]
    while(stack.length) {
        let u = stack.shift()
        let v = stack.shift()
        if (!u && !v) {
            continue
        }
        if (!u || !v) {
            return false
        }

        if (u.val !== v.val) {
            return false
        }

        stack.push(u.left)
        stack.push(v.right)

        stack.push(u.right)
        stack.push(v.left)
    }
    return true
};

时间复杂度O(n),空间复杂度O(n)

相关推荐
დ旧言~3 分钟前
【高阶数据结构】图论
算法·深度优先·广度优先·宽度优先·推荐算法
张彦峰ZYF7 分钟前
投资策略规划最优决策分析
分布式·算法·金融
The_Ticker23 分钟前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程
爪哇学长1 小时前
双指针算法详解:原理、应用场景及代码示例
java·数据结构·算法
Dola_Pan1 小时前
C语言:数组转换指针的时机
c语言·开发语言·算法
繁依Fanyi1 小时前
简易安卓句分器实现
java·服务器·开发语言·算法·eclipse
endingCode1 小时前
45.坑王驾到第九期:Mac安装typescript后tsc命令无效的问题
javascript·macos·typescript
烦躁的大鼻嘎2 小时前
模拟算法实例讲解:从理论到实践的编程之旅
数据结构·c++·算法·leetcode
C++忠实粉丝2 小时前
计算机网络socket编程(4)_TCP socket API 详解
网络·数据结构·c++·网络协议·tcp/ip·计算机网络·算法
用户37791362947552 小时前
【循环神经网络】只会Python,也能让AI写出周杰伦风格的歌词
人工智能·算法