【LeetCode热题100】101. 对称二叉树(二叉树)

一.题目要求

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

二.题目难度

简单

三.输入样例

示例 1:

输入:root = [1,2,2,3,4,4,3]

输出:true

示例 2:

输入:root = [1,2,2,null,3,null,3]

输出:false

提示:

树中节点数目在范围 [1, 1000] 内

-100 <= Node.val <= 100

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

四.解题思路

递归或者迭代,递归没写出来qaq

五.代码实现

迭代

cpp 复制代码
class Solution {
public:
    bool isSymmetric(TreeNode* root) {
        if(!root) return false;
        int remained;
        queue<TreeNode*> q;
        vector<int> val;
        q.push(root);
        while(!q.empty())
        {
            remained = q.size();
            while(remained > 0)
            {
                TreeNode* tmp = q.front();
                q.pop();
                remained--;
                if(tmp->left != nullptr) 
                {
                    q.push(tmp->left);
                    val.push_back(tmp->left->val);
                }
                else 
                {
                    val.push_back(999);               
                }
                if(tmp->right) 
                {
                    q.push(tmp->right);
                    val.push_back(tmp->right->val);
                }
                else 
                {
                    val.push_back(999);               
                }
            }
            auto t = val;
            reverse(val.begin(),val.end());         
            if(val != t) return false;
            vector<int>().swap(val);
        }
        return true;
    }
};

递归

cpp 复制代码
class Solution {
public:
    bool check(TreeNode *p, TreeNode *q) {
        if (!p && !q) return true;
        if (!p || !q) return false;
        return p->val == q->val && check(p->left, q->right) && check(p->right, q->left);
    }

    bool isSymmetric(TreeNode* root) {
        return check(root, root);
    }
};

六.题目总结

递归的子问题没拆出来

相关推荐
killer Curry7 分钟前
Polar CTF PWN 简单(1)(持续更新)
笔记·python·算法
Han.miracle12 分钟前
Lombok 构造相关核心注解全解析
java·linux·算法
DeepModel13 分钟前
【概率分布】卡方分布的原理、推导与实战应用
python·算法·概率论
tankeven14 分钟前
NxN棋盘问题00:对角线特性
c++·算法
滴滴答滴答答14 分钟前
机考刷题之 23&24&25 LeetCode 55&213&123
算法·leetcode·职场和发展
2501_9110882323 分钟前
C++中的代理模式变体
开发语言·c++·算法
客卿12325 分钟前
岛屿问题--bfs的应用--二维网络题目学习
学习·算法·宽度优先
无限进步_25 分钟前
【C++】只出现一次的数字 III:位运算的巧妙应用
数据结构·c++·git·算法·leetcode·github·visual studio
2401_9001515428 分钟前
代码覆盖率工具实战
开发语言·c++·算法