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;
    }
};
相关推荐
don't_be_bald18 分钟前
数据结构与算法-顺序表
c语言·开发语言·数据结构·学习·链表
&白帝&21 分钟前
Java数据类型
java·python·算法
工一木子31 分钟前
【Leecode】Leecode刷题之路第99天之恢复二叉搜索树
java·算法·leetcode·二叉树·中序遍历
帅到爆的努力小陈37 分钟前
进制转换(蓝桥杯)
java·数据结构·算法
Espresso Macchiato1 小时前
Leetcode 3407. Substring Matching Pattern
leetcode·字符串匹配·leetcode easy·leetcode 3407·leetcode双周赛147
Smark.1 小时前
(leetcode算法题)371. 两整数之和
算法·leetcode
KpLn_HJL1 小时前
leetcode - 1769. Minimum Number of Operations to Move All Balls to Each Box
算法·leetcode·职场和发展
格林威2 小时前
Baumer工业相机堡盟LXT工业相机如何升级固件使得相机具有RDMA功能
人工智能·数码相机·算法·计算机视觉·c#
00Allen002 小时前
XXX公司面试真题
java·算法·面试·职场和发展·idea
从以前2 小时前
题解:A. Noldbach Problem
算法