题解 | #对称的二叉树#
对称的二叉树
https://www.nowcoder.com/practice/ff05d44dfdb04e1d83bdbdab320efbcb
/**
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
使用递归的关键:提取出在两颗树中各取一个点的逻辑判断,同时创造性的在入口处指定两个点;
* };
*/
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param pRoot TreeNode类
* @return bool布尔型
*/
bool isSymmetrical(TreeNode* pRoot) {
if (pRoot == nullptr)
return true;
return IsSymmetricalRecursive(pRoot, pRoot);
}
bool IsSymmetricalRecursive(TreeNode* lhs, TreeNode* rhs) {
if (lhs == nullptr && rhs == nullptr)
return true;
if (lhs == nullptr && rhs != nullptr ||
lhs != nullptr && rhs == nullptr)
return false;
if (lhs->val != rhs->val)
return false;
return IsSymmetricalRecursive(lhs->left, rhs->right) &&
IsSymmetricalRecursive(lhs->right, rhs->left);
}
};
查看18道真题和解析