力扣101.对称二叉树(java)

题目来源

101. 对称二叉树 - 力扣(LeetCode)

代码1(递归)

java 复制代码
/**
 * 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) {
        if(root == null) return true;
        return isMirror(root.left,root.right);
    }
    //判断两是否对称
    private boolean isMirror(TreeNode left, TreeNode right) {
        if(left==null && right==null) return true;
        //只有一个为空
        if(left==null || right==null) return false;
        if(left.val != right.val) return false;
        // 左左与右右 左右与右左
        return isMirror(left.left,right.right) && isMirror(left.right,right.left);
    }
}

代码分析

两子树是否对称最小规模子问题就是:

  1. 左子树 与 右子树是否堆成

(对称:左子树与右子树是否都为空,两值是否都为空, 不对称:只有一值为空)

  1. 左子树的左子树与 右子树的右子树 是否同时与 左子树的右子树与 右子树的左子树 均为对称

代码2(dfs迭代法)

java 复制代码
/**
 * 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) {
        if(root == null) return true;

        Stack<TreeNode> stack = new Stack<>();
        stack.push(root.right);
        stack.push(root.left);

        while(!stack.isEmpty()) {
            TreeNode node1 = stack.pop(); //左子树根结点
            TreeNode node2 = stack.pop(); //右

            if(node1==null && node2==null) continue;
            if(node1==null || node2==null || node1.val!=node2.val) return false;
            // if(node1==null || node2==null) return false;
            // if( node1.val!=node2.val) return false;
            //将......逆向入栈 : 左左与右右  左右与右左
            // 入栈就是为了 看两子树是否对称
            stack.push(node2.left);
            stack.push(node1.right);
            stack.push(node2.right);
            stack.push(node1.left);
        }
        return true;
    }
}

代码分析

这里的dfs,是双向深入的dfs。因为需要两子树进行比较。

代码3(bfs迭代法)

java 复制代码
/**
 * 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) {
        if(root == null) return true;

        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root.left);
        queue.offer(root.right);

        while(!queue.isEmpty()) {
            TreeNode node1 = queue.poll();
            TreeNode node2 = queue.poll();

            if(node1==null && node2==null) continue;
            if(node1==null || node2==null || node1.val!=node2.val) return false;

            queue.offer(node1.left);
            queue.offer(node2.right);
            queue.offer(node1.right);
            queue.offer(node2.left);
        }
        return true;
    }
}

代码分析

类似dfs,只是逐层处理。

相关推荐
执着2593 分钟前
力扣hot100 - 199、二叉树的右视图
数据结构·算法·leetcode
I_LPL7 分钟前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归
可编程芯片开发14 分钟前
基于PSO粒子群优化PI控制器的无刷直流电机最优控制系统simulink建模与仿真
人工智能·算法·simulink·pso·pi控制器·pso-pi
cpp_250114 分钟前
P8448 [LSOT-1] 暴龙的土豆
数据结构·c++·算法·题解·洛谷
YGGP15 分钟前
【Golang】LeetCode 49. 字母异位词分组
leetcode
lcj251115 分钟前
深入理解指针(4):qsort 函数 & 通过冒泡排序实现
c语言·数据结构·算法
fie888916 分钟前
基于MATLAB的转子动力学建模与仿真实现(含碰摩、不平衡激励)
开发语言·算法·matlab
唐梓航-求职中23 分钟前
编程大师-技术-算法-leetcode-1472. 设计浏览器历史记录
算法·leetcode
_OP_CHEN26 分钟前
【算法基础篇】(五十八)线性代数之高斯消元法从原理到实战:手撕模板 + 洛谷真题全解
线性代数·算法·蓝桥杯·c/c++·线性方程组·acm/icpc·高斯消元法
YGGP32 分钟前
【Golang】LeetCode 1. 两数之和
leetcode