小白同学对于二叉树还是不太了解的,作者推荐:二叉树的初步认识_加瓦不加班的博客-CSDN博客
对称二叉树-力扣 101 题
data:image/s3,"s3://crabby-images/19520/19520314347d78e15bbb7e4fe200c8489e74d6e0" alt=""
data:image/s3,"s3://crabby-images/02148/02148cae471cd93e85c0af7e6a2fa50e37033ecd" alt=""
作者给的图:
data:image/s3,"s3://crabby-images/95d0f/95d0f8dd17e28c31a0c6022429920ec029f6bc61" alt=""
代码:
java
public boolean isSymmetric(TreeNode root) {
//刚刚开始,传入的是顶堆的左、右两个子叶
return check(root.left, root.right);
}
public boolean check(TreeNode left, TreeNode right) {
// 若同时为 null:也就是整个二叉树就只有一个元素就是顶堆
if (left == null && right == null) {
return true;
}
// 若有一个为 null (有上一轮筛选,另一个肯定不为 null)
if (left == null || right == null) {
return false;
}
//都不为null,则查看值相不相同
if (left.val != right.val) {
return false;
}
return check(left.left, right.right) && check(left.right, right.left);
}
代码解析:
data:image/s3,"s3://crabby-images/7125f/7125fc40a05a823ae00c26bf724413e9b005f51e" alt=""
类似题目:Leetcode 100 题 - 相同的树