对称二叉树(力扣101)

题目如下:

思路

对于这道题, 我会采用递归的解法.

看着对称的二叉树,

写下判断对称的条件,

再进入递归即可.

值得注意的是,

代码中会有两个函数,

第一个是isSymmetric,第二个是judge.

因为这里会考虑到一种特殊情况,

那就是

二叉树的根结点(最上面的那个),它会单独用isSymmetric判断一下,

judge则用来判断根节点的左右两边结点的对称.

代码中有具体注释,请大家看代码.

代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */


//注意传参,比较的是一个节点的左右子树
bool judge(struct TreeNode*left,struct TreeNode*right)
{

    if(left==NULL&&right==NULL)
    {
        return true;
    }
    if(left==NULL||right==NULL)
    {
        return false;
    }
    if(left->val!=right->val)
    {
        return false;
    }

    //再次注意传参,由示例的图可知传参参数的对称性
    return judge(left->left,right->right)&&judge(left->right,right->left);
}

bool isSymmetric(struct TreeNode* root) {

    //空树对称返回true
    if(root==NULL)
    {
        return true;
    }

    //左右子树都为空
    if(root->left==NULL&&root->right==NULL)
    {
        return true;
    }

    //左右子树中有一颗不为空
    if(root->left==NULL||root->right==NULL)
    {
        return false;
    }

    //判断是否对称
    if(root->left->val!=root->right->val)
    {
        return false;
    }

    //进入递归
    return judge(root->left,root->right);
}
相关推荐
I_LPL16 小时前
day36 代码随想录算法训练营 动态规划专题4
java·算法·leetcode·动态规划·hot100
ab15151716 小时前
2.24完成129、134、135
数据结构·算法
2301_8169978816 小时前
虚拟DOM与Diff算法
前端·vue.js·算法
闻缺陷则喜何志丹16 小时前
P8153 「PMOI-5」送分题/Yet Another Easy Strings Merging|普及+
c++·数学·算法·洛谷
tankeven16 小时前
HJ102 字符统计
c++·算法
升讯威在线客服系统16 小时前
从 GC 抖动到稳定低延迟:在升讯威客服系统中实践 Span 与 Memory 的高性能优化
java·javascript·python·算法·性能优化·php·swift
We་ct16 小时前
LeetCode 199. 二叉树的右视图:层序遍历解题详解
前端·算法·leetcode·typescript·广度优先
孤独的追光者16 小时前
MATLAB导出滤波器参数至ADSP中使用
算法·matlab
鲨辣椒1008616 小时前
线程函数接口补充
java·开发语言·算法
0 0 016 小时前
CCF-CSP 33-2 相似度计算(jaccard)【C++】考点:STL容器(set/map)
开发语言·c++·算法