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是树的节点数。对每个节点访问一次。
相关推荐
图学习小组17 分钟前
PaCon:一种用于识别编程提交中问题求解策略的符号分析方法
人工智能·算法·机器学习
JHC00000020 分钟前
119. 杨辉三角 II
python·算法·面试
剪一朵云爱着21 分钟前
PAT 1158 Telefraud Detection
算法·pat考试
embrace9926 分钟前
【C语言学习】预处理详解
java·c语言·开发语言·数据结构·c++·学习·算法
拼好饭和她皆失28 分钟前
《二分答案算法精讲:从原理到实战(上篇)》
c++·算法
好风凭借力,送我上青云31 分钟前
Pytorch经典卷积神经网络-----激活函数篇
人工智能·pytorch·深度学习·算法·矩阵·cnn
Tisfy33 分钟前
LeetCode 3652.按策略买卖股票的最佳时机:滑动窗口
算法·leetcode·题解·滑动窗口
扫地的小何尚35 分钟前
NVIDIA CUDA-Q QEC权威指南:实时解码、GPU解码器与AI推理增强
人工智能·深度学习·算法·llm·gpu·量子计算·nvidia
重生之我是Java开发战士38 分钟前
【数据结构】优先级队列(堆)
java·数据结构·算法
菜鸟233号38 分钟前
力扣216 组合总和III java实现
java·数据结构·算法·leetcode