C++速通LeetCode简单第11题-对称二叉树

递归法:

cpp 复制代码
/**
 * 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 isSymmetric(TreeNode* root) {
        return isMirror(root,root);    
    }

    bool isMirror(TreeNode* t1,TreeNode* t2)
    {
        if(t1==nullptr&&t2==nullptr)
        return true;

        if(t1==nullptr||t2==nullptr)
        return false;

        return((t1->val==t2->val)&&isMirror(t1->right,t2->left)&&isMirror(t1->left,t2->right));
    }
};
相关推荐
小新1106 分钟前
vs2022+Qt插件初体验,创建带 UI 界面的 Qt 项目
开发语言·qt·ui
摘星编程14 分钟前
Ascend C编程语言详解:打造高效AI算子的利器
c语言·开发语言·人工智能
我不会插花弄玉32 分钟前
string类-上【由浅入深-C++】
c++
雨中飘荡的记忆32 分钟前
Java面向对象编程详解
java·开发语言
添砖java‘’34 分钟前
Linux信号机制详解:从产生到处理
linux·c++·操作系统·信号处理
月明长歌37 分钟前
【码道初阶】【LeetCode 958】判定完全二叉树:警惕 BFS 中的“管中窥豹”陷阱
算法·leetcode·宽度优先
MC皮蛋侠客1 小时前
Linux C++使用GDB调试动态库崩溃问题完全指南
linux·c++
超轶绝尘1 小时前
C++学习笔记 23 宏 Macro
c++
222you1 小时前
线程的常用方法
java·开发语言
云栖梦泽1 小时前
易语言界面美化与组件扩展
开发语言