自学内容网 自学内容网

力扣101. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。



提示:

  • 树中节点数目在范围 [1, 1000] 内
  • -100 <= Node.val <= 100

进阶:你可以运用递归和迭代两种方法解决这个问题吗?


代码:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    bool check(TreeNode* p, TreeNode* q){
        if(p == nullptr && q == nullptr) return true;
        if(p == nullptr || q == nullptr) return false;

        if(p->val == q->val){
            return check(p->right, q->left) && check(p->left,q->right);
        }
        return false;
    }

    bool isSymmetric(TreeNode* root) {
        return check(root->left, root->right);
    }
};

解题思路:

(1)从根节点开始,使用两个指针 p 和 q 遍历二叉树。

(2)判断两个指针的值是否相同,并且 p 往左移时,q 往右移;p 往右移时,q 往左移。


原文地址:https://blog.csdn.net/m0_57879843/article/details/144066614

免责声明:本站文章内容转载自网络资源,如侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!