力扣hot100 - 101、对称二叉树

题目:

思路:判断是不是对称二叉树,本质上是判断根节点左右子树是否可以相互翻转。整体思路:比较左右子树的外边及里边,如果都相等就是对称二叉树。确定遍历顺序:这类题最好用后续遍历左右中,把左右孩子的信息处理完返回给上一层。递归前先判断一些一定是对称或一定是不对称的情况,左右都空、左空右不空、左不空右空、左右值不相等;注意把左右空放前面避免控制针;我们真正要递归处理的情况是左右不空且值相等,这是要判断左右子树外侧及内侧是否相同。

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) {
       return a(root.left,root.right);
    }

    boolean a(TreeNode l , TreeNode r){
        if(l == null && r == null){
            return true;
        }else if(l == null && r != null){
            return false;
        }else if(l != null && r == null){
            return false;
        }else if(l.val != r.val){
            return false;
        }else{
            boolean outside = a(l.left,r.right);
            boolean inside = a(l.right,r.left);
            return outside && inside;
        }
    }
}
相关推荐
fengenrong8 分钟前
20260429
c++·算法
南宫萧幕10 分钟前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
apollowing25 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(优)
算法·启发式算法·web app
liuyao_xianhui35 分钟前
进程概念与进程状态_Linux
linux·运维·服务器·数据结构·c++·哈希算法·宽度优先
如君愿36 分钟前
考研复习 Day 26 | 习题--计算机网络第三章(数据链路层 下)、数据结构 多维数组与广义表
数据结构·计算机网络·考研·记录考研
bqq1986102643 分钟前
MySQL分库分表
数据结构·mysql
迷途之人不知返1 小时前
List的模拟实现
数据结构·c++·学习·list
Chat_zhanggong3451 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage2 小时前
算法:线段树
算法
Westward-sun.2 小时前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类