2019-05-02 15:59:01 +08:00
|
|
|
|
# LeetCode 第 101 号问题:对称二叉树
|
|
|
|
|
|
|
|
|
|
> 本文首发于公众号「五分钟学算法」,是[图解 LeetCode ](<https://github.com/MisterBooo/LeetCodeAnimation>)系列文章之一。
|
|
|
|
|
>
|
|
|
|
|
> 个人网站:[https://www.cxyxiaowu.com](https://www.cxyxiaowu.com)
|
|
|
|
|
|
|
|
|
|
题目来源于 LeetCode 第 101 号问题:对称二叉树。
|
|
|
|
|
|
|
|
|
|
### 题目描述
|
|
|
|
|
|
|
|
|
|
给定一个二叉树,检查它是否是镜像对称的。
|
|
|
|
|
|
|
|
|
|
例如,二叉树 `[1,2,2,3,4,4,3]` 是对称的。
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
1
|
|
|
|
|
/ \
|
|
|
|
|
2 2
|
|
|
|
|
/ \ / \
|
|
|
|
|
3 4 4 3
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 题目解析
|
|
|
|
|
|
|
|
|
|
用递归做比较简单:一棵树是对称的**等价**于它的左子树和右子树两棵树是对称的,问题就转变为判断两棵树是否对称。
|
|
|
|
|
|
|
|
|
|
### 代码实现
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
class Solution {
|
|
|
|
|
public boolean isSymmetric(TreeNode root) {
|
|
|
|
|
if(root == null) return true;
|
|
|
|
|
//把问题变成判断两棵树是否是对称的
|
|
|
|
|
return isSym(root.left, root.right);
|
|
|
|
|
}
|
|
|
|
|
//判断的是根节点为r1和r2的两棵树是否是对称的
|
|
|
|
|
public boolean isSym(TreeNode r1, TreeNode r2){
|
|
|
|
|
if(r1 == null && r2 == null) return true;
|
|
|
|
|
if(r1 == null || r2 == null) return false;
|
|
|
|
|
//这两棵树是对称需要满足的条件:
|
|
|
|
|
//1.俩根节点相等。 2.树1的左子树和树2的右子树,树2的左子树和树1的右子树都得是对称的
|
|
|
|
|
return r1.val == r2.val && isSym(r1.left, r2.right)
|
|
|
|
|
&& isSym(r1.right, r2.left);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2019-11-14 11:00:28 +08:00
|
|
|
|
![](https://blog-1257126549.cos.ap-guangzhou.myqcloud.com/blog/kbvfp.gif)
|