LeetCode 101. 对称二叉树 [Symmetric Tree (Easy)]

给定一个二叉树,检查它是否是镜像对称的。

LeetCode 101. 对称二叉树 [Symmetric Tree (Easy)]

 

 

来源:力扣(LeetCode)


/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    bool isSymmetric(TreeNode* root) {
        if (root == nullptr) return true;
        return isSymmetricCore(root->left, root->right);
    }
    bool isSymmetricCore(TreeNode* pNode1, TreeNode* pNode2)
    {
        if (pNode1 == nullptr && pNode2 == nullptr)  //对应节点都为空
            return true;
        if (pNode1 == nullptr || pNode2 == nullptr)  //只有一个节点为空
            return false;
        if (pNode1->val != pNode2->val) return false;
        return isSymmetricCore(pNode1->left, pNode2->right) &&
        isSymmetricCore(pNode1->right, pNode2->left);
    }
};

 

上一篇:101. Symmetric Tree


下一篇:Leetcode 101. Symmetric Tree