算法训练Day17|● 104.二叉树的最大深度 559.n叉树的最大深度● 111.二叉树的最小深度● 222.完全二叉树的节点个数

简介: 算法训练Day17|● 104.二叉树的最大深度 559.n叉树的最大深度● 111.二叉树的最小深度● 222.完全二叉树的节点个数

LeetCode:104.二叉树的最大深度

104.二叉树的最大深度-力扣(leetcode)

1.思路

递归方法来实现

理论上,深度应该从根节点计数,直到最深的叶子节点。故采用前序遍历是统一的。

高度应该从叶子节点计数,直到根节点为止。故采用后序遍历时统一的。

但,由于最大深度和最大高度是同一个数值,所以前序遍历和后续遍历结果是一致的。

但,层序遍历应该是最好理解的。


2.代码实现

递归实现

 1// 递归
 2class Solution {
 3    public int maxDepth(TreeNode root) {
 4        if (root == null) {
 5            return 0;
 6        }
 7        int getLeft = maxDepth(root.left);
 8        int getright = maxDepth(root.right);
 9        return Math.max(getLeft, getright) + 1; // 遇到最底层节点进行 +1 操作, 这个过程属于回溯
10    }   
11}
迭代法实现(层序遍历

该代码通过广度优先搜索(BFS)的方式计算二叉树的最大深度。使用一个队列来存储每一层的节点,每次遍历完一层后,深度加1。直到队列为空,即遍历完整个二叉树,返回最大深度。

 1class Solution {
 2    public int maxDepth(TreeNode root) {
 3        if (root == null) { // 如果根节点为空,返回深度为0
 4            return 0;
 5        }
 6        Queue<TreeNode> queue = new LinkedList<>(); // 创建一个队列来存储节点
 7        queue.offer(root); // 将根节点加入队列
 8        int ans = 0; // 初始化深度为0
 9        while (!queue.isEmpty()) { // 当队列不为空时循环
10            int size = queue.size(); // 获取当前层的节点数量
11            while (size > 0) { // 遍历当前层的所有节点
12                TreeNode node = queue.poll(); // 从队列中取出一个节点
13                if (node.left != null) { // 如果节点的左子节点不为空,将左子节点加入队列
14                    queue.offer(node.left);
15                }
16                if (node.right != null) { // 如果节点的右子节点不为空,将右子节点加入队列
17                    queue.offer(node.right);
18                }
19                size--; // 当前层节点数量减1
20            }
21            ans++; // 每遍历完一层,深度加1
22        }
23        return ans; // 返回最大深度
24    }
25}

3.复杂度分析

递归:

时间复杂度:O(n),需要遍历到每个节点,故为O(n)

空间复杂度:O(height),用栈存储深度,所以空间消耗为height/depth.

层序:

时间复杂度:O(n),需要遍历到每个节点,故为O(n)

空间复杂度:O(n)+O(size)+O(ans),用队列暂存,额外用到size、ans..


LeetCode:559.n叉树的最大深度

559.N叉树的最大深度-力扣(leetcode)

1.思路

2.代码实现

 1class Solution {
 2    public int minDepth(TreeNode root) {
 3        if (root == null) {
 4            return 0;
 5        }
 6        int getLeft = minDepth(root.left);
 7        int getRight = minDepth(root.right);
 8        // 左子树为null时
 9        if (root.left == null) {
10            return getRight + 1;
11        }
12        // 右子树为null
13        if (root.right == null) {
14            return getLeft + 1;
15        }
16        // 根节点左右子树都不为null时,取两子树较小值
17        return Math.min(getLeft, getRight) + 1;
18    }
19}

3.复杂度分析

时间复杂度:O(logN/2 ✖ logN/2)

空间复杂度:O(1),常数项存储最大深度的数值


LeetCode:111.二叉树的最小深度

111. 二叉树的最小深度 - 力扣(LeetCode)


1.思路

最小深度和最大深度思路基本一致,需要注意的是,要排除根节点左右子树为空的情况。

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


2.代码实现

 1class Solution {
 2    public int minDepth(TreeNode root) {
 3        if (root == null) {
 4            return 0;
 5        }
 6        int getLeft = minDepth(root.left);
 7        int getRight = minDepth(root.right);
 8        // 左子树为null时
 9        if (root.left == null) {
10            return getRight + 1;
11        }
12        // 右子树为null
13        if (root.right == null) {
14            return getLeft + 1;
15        }
16        // 根节点左右子树都不为null时,取两子树较小值
17        return Math.min(getLeft, getRight) + 1;
18    }
19}

3.复杂度分析

时间复杂度:遍历每个节点,故为O(N)

空间复杂度:取决于递归时,栈空间的开销。最坏情况下,树呈链状,空间复杂度为O(N),平均情况下树的高度与节点数的对数呈正相关,空间复杂度为O(logN).

LeetCode:222.完全二叉树的节点个数

222.完全二叉树的节点个数-力扣(leetcode)

1.思路

2.代码实现

递归法
 1// 递归实现
 2class Solution {
 3    public int countNodes(TreeNode root) {
 4        if (root == null) {
 5            return 0;
 6        }
 7        int leftCount = countNodes(root.left);
 8        int rightCount = countNodes(root.right);
 9        int sum = leftCount + rightCount + 1;
10        return sum;
11    }
12}
迭代法
 1// 迭代法
 2class Solution {
 3    public int countNodes(TreeNode root) {
 4        if (root == null) {
 5            return 0;
 6        }
 7        Queue<TreeNode> queue = new LinkedList<>(); // 创建层序遍历的辅助队列
 8        queue.offer(root);
 9        int sum = 0;
10        while (!queue.isEmpty()) {
11            int size = queue.size();
12            while (size > 0) {
13                TreeNode cur = queue.poll();
14
15                size--;
16                sum++;
17                if (cur.left != null) {
18                    queue.offer(cur.left);
19                }
20                if (cur.right != null) {
21                    queue.offer(cur.right);
22                }  
23            }
24        }
25        return sum;
26    }
27}

3.复杂度分析

递归法:

时间复杂度:O(logN/2 ✖ logN/2)

空间复杂度:O(N),代码随想录给的是O(logN),存疑!

相关文章
|
10天前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
42 9
 算法系列之数据结构-二叉树
|
7天前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
32 3
 算法系列之数据结构-Huffman树
|
1月前
|
传感器 算法 物联网
基于粒子群算法的网络最优节点部署优化matlab仿真
本项目基于粒子群优化(PSO)算法,实现WSN网络节点的最优部署,以最大化节点覆盖范围。使用MATLAB2022A进行开发与测试,展示了优化后的节点分布及其覆盖范围。核心代码通过定义目标函数和约束条件,利用PSO算法迭代搜索最佳节点位置,并绘制优化结果图。PSO算法灵感源于鸟群觅食行为,适用于连续和离散空间的优化问题,在通信网络、物联网等领域有广泛应用。该算法通过模拟粒子群体智慧,高效逼近最优解,提升网络性能。
|
2月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
61 2
|
3月前
|
存储 算法 Python
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
75 5
|
2月前
|
传感器 算法
基于GA遗传优化的WSN网络最优节点部署算法matlab仿真
本项目基于遗传算法(GA)优化无线传感器网络(WSN)的节点部署,旨在通过最少的节点数量实现最大覆盖。使用MATLAB2022A进行仿真,展示了不同初始节点数量(15、25、40)下的优化结果。核心程序实现了最佳解获取、节点部署绘制及适应度变化曲线展示。遗传算法通过初始化、选择、交叉和变异步骤,逐步优化节点位置配置,最终达到最优覆盖率。
|
5天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于生物地理算法的MLP多层感知机优化matlab仿真
本程序基于生物地理算法(BBO)优化MLP多层感知机,通过MATLAB2022A实现随机数据点的趋势预测,并输出优化收敛曲线。BBO模拟物种在地理空间上的迁移、竞争与适应过程,以优化MLP的权重和偏置参数,提升预测性能。完整程序无水印,适用于机器学习和数据预测任务。
|
4天前
|
资源调度 算法 数据可视化
基于IEKF迭代扩展卡尔曼滤波算法的数据跟踪matlab仿真,对比EKF和UKF
本项目基于MATLAB2022A实现IEKF迭代扩展卡尔曼滤波算法的数据跟踪仿真,对比EKF和UKF的性能。通过仿真输出误差收敛曲线和误差协方差收敛曲线,展示三种滤波器的精度差异。核心程序包括数据处理、误差计算及可视化展示。IEKF通过多次迭代线性化过程,增强非线性处理能力;UKF避免线性化,使用sigma点直接处理非线性问题;EKF则通过一次线性化简化处理。
|
6天前
|
算法 数据安全/隐私保护
基于二次规划优化的OFDM系统PAPR抑制算法的matlab仿真
本程序基于二次规划优化的OFDM系统PAPR抑制算法,旨在降低OFDM信号的高峰均功率比(PAPR),以减少射频放大器的非线性失真并提高电源效率。通过MATLAB2022A仿真验证,核心算法通过对原始OFDM信号进行预编码,最小化最大瞬时功率,同时约束信号重构误差,确保数据完整性。完整程序运行后无水印,展示优化后的PAPR性能提升效果。
|
3天前
|
算法 数据安全/隐私保护 计算机视觉
基于sift变换的农田杂草匹配定位算法matlab仿真
本项目基于SIFT算法实现农田杂草精准识别与定位,运行环境为Matlab2022a。完整程序无水印,提供详细中文注释及操作视频。核心步骤包括尺度空间极值检测、关键点定位、方向分配和特征描述符生成。该算法通过特征匹配实现杂草定位,适用于现代农业中的自动化防控。

热门文章

最新文章