题意:
给定一个二叉树,检查它是否是镜像对称的。
中间划开,看是否对称
例如,二叉树 [1,2,2,3,4,4,3] 是对称的。
1
/
2 2
/ \ /
3 4 4 3
思路:(递归法)
这里镜像对称,也就是左子树和右子树要相等,细说就是左子树的左节点与右子树的右节点对称,左子树的右节点与右子树的左节点对称。这里意思就是递归比较左子树和右子树
如果用递归,我们就要找到终止条件,这里有:
1,两个节点都为空
2,两个节点有一个为空
3,两个节点的值不相等
上述三种情况返回false
4,其它用递归函数dfs解决
首先肯定是判空,跟数组,链表等数据结构类似
接下来各种情况,调用递归函数。
Java代码实现:
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public boolean isSymmetric(TreeNode root) {
if(root==null) {
return true;
}
return dfs(root.left,root.right);//调用递归函数,比较左节点,右节点
}
boolean dfs(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 dfs(left.left,right.right) && dfs(left.right,right.left);
}
}