LeetCode-101. 对称二叉树

Problem: 101. 对称二叉树

文章目录

思路

看到这个题,想到的解题方法是使用递归实现。判断二叉树是否对称,需要判断根节点的左子树和右子树是否对称。所以从根节点开始,递归判断左子树的左节点是否和右子树的右节点是否相同,左子树的右节点和右子树的左节点是否相同。如下图所示:

解题方法

从根节点开始,递归判断判断左子树的左节点是否和右子树的右节点是否相同,左子树的右节点和右子树的左节点是否相同。如果两个节点同时为空,返回true,都不为空的情况下判断val是否相同,相同则调用递归方法进入下一层判断。其他情况返回false

Code

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 judge(root.left,root.right);
             
    }
    public boolean judge(TreeNode l , TreeNode r){
        if(l==null && r==null){
            return true;
        }
        if(l!=null && r!=null){
            if(l.val == r.val){
                return judge(l.left,r.right) && judge(l.right,r.left);
            }
        }
        return false;
    }
}

结果

相关推荐
测试19984 小时前
软件测试 - 单元测试总结
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
心中有国也有家8 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事8 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院8 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet9 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
一只机电自动化菜鸟11 小时前
一建机电备考笔记(40) 建筑机电施工—排水管道施工(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
m0_6294947312 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户12 小时前
用队列实现栈
数据结构·算法
做人求其滴12 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣