https://leetcode-cn.com/problems/symmetric-tree/
/*
* @Author: Goog Tech
* @Date: 2020-07-29 00:07:21
* @Description: https://leetcode-cn.com/problems/symmetric-tree/
* @FilePath: \leetcode-googtech\#102. Binary Tree Level Order Traversal\101.对称二叉树.java
*/
/*
* @lc app=leetcode.cn id=101 lang=java
*
* [101] 对称二叉树
*/
// @lc code=start
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
/**
* 递归法: 解题思路如下
* 有个超大的坑啊: 记得首先判断 left == null && right == null
* 而不是 left == null || right == null,不然无论什么结果都会一直返回 False
* 1. 若左右子树中的两节点都非空,则对称
* 2. 若左右子树中的两节点其有一个为空,则不对称
* 3. 若左右子树中的两节点不相同,则不对称
* 4. 继续递归比较左节点的左孩子和右节点的右孩子
*/
public boolean isSymmetric(TreeNode root) {
// if(root == null) return true;
// return dfs(root.left, root.right);
return root == null ? true : dfs(root.left, root.right); // 若根节点不为空则传入左右子树的根节点
}
private boolean dfs(TreeNode left, TreeNode right) {
// if(left == null && right == null) return true;
// if(left == null || right == null || left.val != right.val) return false;
// return dfs(left.left, right.right, left.right, right.left);
return left == null && right == null ? true : left == null || right == null || left.val != right.val ? false : dfs(left.left, right.right) && dfs(left.right, right.left);
}
}
// @lc code=end
'''
@Author: Goog Tech
@Date: 2020-07-28 23:12:04
@Description: https://leetcode-cn.com/problems/symmetric-tree/
@FilePath: \leetcode-googtech\#102. Binary Tree Level Order Traversal\101.对称二叉树.py
'''
#
# @lc app=leetcode.cn id=101 lang=python
#
# [101] 对称二叉树
#
# @lc code=start
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
# 递归法
# 有个超大的坑啊: 记得首先判断 if not left and not right
# 而不是 if not left or not right,不然无论什么结果都会一直返回 False
def isSymmetric(self, root):
"""
:type root: TreeNode
:rtype: bool
"""
if not root:
return True
def dfs(left, right):
# 若左右子树中的两节点都非空,则对称
if not left and not right: return True
# 若左右子树中的两节点其有一个为空,则不对称
if not left or not right: return False
# 若左右子树中的两节点不相同,则不对称
if left.val != right.val: return False
# 继续递归比较左节点的左孩子和右节点的右孩子
return dfs(left.left, right.right) and dfs(left.right, right.left)
# 传入左右子树的根节点
return dfs(root.left, root.right)
# @lc code=end