leetcode101.对称二叉树

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 compare(TreeNode* left,TreeNode* right){
        //左右节点都空为真,一空一有为假,都有则进一步判断
        if(left==NULL&&right==NULL)
            return true;
        else if(left==NULL&&right!=NULL)
            return false;
        else if(left!=NULL&&right==NULL)
            return false;
        else{
            //两者数值不等为假,两者数值相等则递归比较外侧和里侧
            if(left->val!=right->val)
                return false;
            else{
                bool outSide=compare(left->left,right->right);
                bool inSide=compare(left->right,right->left);
                return outSide&&inSide;
            }
        }
    }
    bool isSymmetric(TreeNode* root) {
        if(root==NULL)
            return true;
        else   
            return compare(root->left,root->right);
    }
};
相关推荐
Gary Studio3 分钟前
第三类笔记
笔记·算法
C30_01 小时前
10.4作业
算法
lingchen19062 小时前
b = [1 2 3;4 5 6;7 8 9]>> b(2,2)=[ ]??? Subscripted assignme
数据结构·算法
Mr_Xuhhh2 小时前
哈希扩展学习
学习·算法·哈希算法
sxtyjty2 小时前
ABC426G - Range Knapsack Query
c++·算法·分治
dog2502 小时前
时延抖动的物理本质
人工智能·算法·机器学习
Vect__2 小时前
二叉树实战笔记:结构、遍历、接口与 OJ 实战
数据结构·c++·算法
hahaha60163 小时前
高层次综合基础-vivado hls第三章
算法·fpga开发
smallnetter4 小时前
华为OD机试C卷 - 分苹果 - 二进制 - (Java & C++ & JavaScript & Python)
算法·华为od