力扣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)!