12.1 二叉树简单题

101. 对称二叉树

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

示例 1:

复制代码
输入:root = [1,2,2,3,4,4,3]
输出:true

思路:对称二叉树 有一个特点是以 中左右顺序遍历左子树的结果会等于 中右左顺序遍历右子树的结果。则用递归的方式

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 isEquel(TreeNode* left,TreeNode* right)
    {
        if(!left && !right) return true;
        else if(!left || !right) return false;
        if(left->val == right->val) 
        {
            return isEquel(left->left,right->right) && isEquel(left->right,right->left);
        }
        else
        {
            return false;
        }

    }
    bool isSymmetric(TreeNode* root) {
        //左子树  中左右序 遍历的结果 = 右子树 中右左序 遍历的结果
        if(!root||!root->left&&!root->right) return true;
        if(!root->left || !root->right) return false;
        return isEquel(root->left,root->right);
    }
};
  • 时间复杂度:这里遍历了这棵树,渐进时间复杂度为 O(n)。

111. 二叉树的最小深度

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

**说明:**叶子节点是指没有子节点的节点。

示例 1:

复制代码
输入:root = [3,9,20,null,null,15,7]
输出:2

思路:题目中是要求找 到叶子节点(左 右子节点为nullptr)的最小深度,并不是空节点的最小深度。

可以用深度优先遍历该树,每次到叶子节点则进行最小值的迭代判断。

细节:引入记录当前深度和最小值的 变量

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:
    void findMinDepth(TreeNode* root,int& depth,int& cur)
    {
        if(!root) return;
        else if(!root->left && !root->right)
        {
            depth=min(depth,cur+1);
        }
        cur++;
        findMinDepth(root->left,depth,cur);
        findMinDepth(root->right,depth,cur);
        cur--;
        return;
    }
    int minDepth(TreeNode* root) 
    {
        if(root)
        {
            int depth=INT_MAX;
            int cur=0;
            findMinDepth(root,depth,cur);
            return depth;
        }
        else return 0;
    }
};
  • 时间复杂度:O(N),其中 N是树的节点数。对每个节点访问一次。
相关推荐
晚霞的不甘6 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频
望舒5136 小时前
代码随想录day25,回溯算法part4
java·数据结构·算法·leetcode
C++ 老炮儿的技术栈6 小时前
Qt 编写 TcpClient 程序 详细步骤
c语言·开发语言·数据库·c++·qt·算法
KYGALYX6 小时前
逻辑回归详解
算法·机器学习·逻辑回归
铉铉这波能秀6 小时前
LeetCode Hot100数据结构背景知识之集合(Set)Python2026新版
数据结构·python·算法·leetcode·哈希算法
参.商.6 小时前
【Day 27】121.买卖股票的最佳时机 122.买卖股票的最佳时机II
leetcode·golang
踢足球09296 小时前
寒假打卡:2026-2-8
数据结构·算法
IT猿手7 小时前
基于强化学习的多算子差分进化路径规划算法QSMODE的机器人路径规划问题研究,提供MATLAB代码
算法·matlab·机器人
千逐-沐风7 小时前
SMU-ACM2026冬训周报3rd
算法
铉铉这波能秀7 小时前
LeetCode Hot100数据结构背景知识之元组(Tuple)Python2026新版
数据结构·python·算法·leetcode·元组·tuple