LeetCode101:对称二叉树

题目描述

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


代码

递归

cpp 复制代码
class Solution {
public:
    bool compare(TreeNode* left, TreeNode* right) {
        if (left == nullptr && right != nullptr) return false;
        else if (left != nullptr && right == nullptr) return false;
        else if (left == nullptr && right == nullptr) return true;
        else if (left->val != right->val) return false;
        
        bool outside = compare(left->left, right->right);
        bool inside = compare(left->right, right->left);
        
        return outside && inside;
;    }

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

迭代

cpp 复制代码
class Solution {
public:
    bool isSymmetric(TreeNode* root) {
        queue<TreeNode*> que;
        que.push(root->left);
        que.push(root->right);
        while (!que.empty()) {
            TreeNode* l = que.front(); que.pop();
            TreeNode* r = que.front(); que.pop();
            //左右都为空,则说明是对称的
            if (l == nullptr && r == nullptr) continue;
            // 左右一个节点不为空,或者都不为空但数值不相同,返回false
            if (l == nullptr || r == nullptr || (l->val != r->val)) return false;

            //外侧
            que.push(l->left); // 加入左节点左孩子
            que.push(r->right);// 加入右节点右孩子
            
            //内侧
            que.push(l->right);// 加入左节点右孩子
            que.push(r->left);// 加入右节点左孩子
        }
        return true;
    }
};
相关推荐
ChoSeitaku7 分钟前
12.重复内容去重|添加日志|部署服务到Linux上(C++)
linux·c++·windows
挣扎与觉醒中的技术人12 分钟前
网络安全入门持续学习与进阶路径(一)
网络·c++·学习·程序人生·安全·web安全
滴_咕噜咕噜14 分钟前
C#基础总结:常用的数据结构
开发语言·数据结构·c#
haaaaaaarry18 分钟前
【分治法】线性时间选择问题
数据结构·算法
CS创新实验室27 分钟前
计算机考研之数据结构:P 问题和 NP 问题
数据结构·考研·算法
OTWOL1 小时前
【C++编程入门基础(一)】
c++·算法
谏君之1 小时前
C语言实现的常见算法示例
c语言·算法·排序算法
宇寒风暖2 小时前
侯捷 C++ 课程学习笔记:内存管理与工具应用
c++·笔记·学习
机器视觉知识推荐、就业指导2 小时前
【数字图像处理二】图像增强与空域处理
图像处理·人工智能·经验分享·算法·计算机视觉
Smile丶凉轩2 小时前
数据库面试知识点总结
数据库·c++·mysql