算法训练Day21|530.二叉搜索树的最小绝对差 ● 501.二叉搜索树中的众数 ● 236. 二叉树的最近公共祖先

简介: 算法训练Day21|530.二叉搜索树的最小绝对差 ● 501.二叉搜索树中的众数 ● 236. 二叉树的最近公共祖先

LeetCode:530.二叉搜索树的最小绝对差

530. 二叉搜索树的最小绝对差 - 力扣(LeetCode)


1.思路

利用二叉搜索树的典型特性:中序遍历输出是一个升序的数组。

在此基础之上结合双指针法可以直接在二叉搜索树上直接进行中序遍历获取最小绝对值差ans。


2. 代码实现

 1class Solution {
 2    TreeNode pre; // 存储前一个节点
 3    int ans = Integer.MAX_VALUE; // 取最小值,因此以最大值为边界
 4
 5    public int getMinimumDifference(TreeNode root) {
 6        // if (root == null) return 0; // 节点数大于2,所以应该省略
 7        traversal(root); // 单层递归函数
 8        return ans; // 返回最小绝对差值:ans
 9    }
10
11    // 构建单层递归的逻辑,传入参数节点root/cur
12    public void traversal(TreeNode root) { 
13        // 确定终止条件 
14        if (root == null) return; // 判断当前节点是否为空,为空直接返回,否则继续递归
15        // 左:向左递归遍历,从叶子节点算起
16        traversal(root.left);
17        // 中:中节点处理逻辑
18        if (pre != null) { // 前节点pre不为空
19            ans = Math.min(ans, root.val - pre.val); // 选取ans和当前节点与前一节点差值的较小值
20        }
21        pre = root; // 将当前节点赋值给前节点pre,双指针法的体现!!!
22        // 右:向右递归遍历,从右子树叶子节点算起...
23        traversal(root.right);
24    }
25}

3. 复杂度分析

时间复杂度:O(n).取决于节点的数量级n.

空间复杂度:O(n).取决于递归函数调用的层数.二叉树最坏情况为一条链表,会达到O(n)级别.普通情况下是O(logn)级别,logn代表递归函数在n个节点时调用的次数.

我悟了!!!!!!!!!!!!!!!!!!

开心就拍手,开心就拍手,开心就把你身边徐真真给带走~


LeetCode:501.二叉搜索树中的众数

501. 二叉搜索树中的众数 - 力扣(LeetCode)


1.思路

暴力解法:遍历整棵树(顺序不重要),用map记录出现的次数,节点值当作key,出现的次数记作value,value进行累加即可。。。。

递归+双指针法:中序遍历,重点在于处理中节点的值。用计数器进行记录,获取计数器最大值即为众数,众数可能为多个,相等时将节点加入即可。

最后将链表中的众数值移动到数组res中,将数组res返回即可.


2. 代码实现

 1class Solution {
 2    // 定义全局变量
 3    ArrayList<Integer> resList = new ArrayList<>(); // list链表存储结果
 4    int maxCount = 0; // 记录众数的大小
 5    int count = 0; // 计数器
 6    TreeNode pre = null; // 前节点
 7
 8    public int[] findMode(TreeNode root) {
 9        // 调用递归函数
10        traversal(root);
11
12        // 将众数值存储数组中,进行记录返回
13        int[] res = new int[resList.size()]; // 创建一个存储众数结果的数组
14        for (int i = 0; i < resList.size(); i++) { 
15            res[i] = resList.get(i); // 将众数的值装入res数组中
16        }
17        return res; // 返回结果
18
19    }
20    // 构建单层递归的逻辑
21    public void traversal(TreeNode root) {
22        if (root == null) return; // 如果节点为空,直接返回
23        // 左:向左遍历
24        traversal(root.left); 
25
26        // 中:计数器用于记录每个节点的众数值
27        if (pre == null || root.val != pre.val) {
28            count = 1; // 前节点为null活当前节点与前节点不等时,该数出现频率为1
29        } else {
30            count++; // 否则进行累加
31        }
32        // 获取众数值最大的值并写入相应的节点值root.val
33        if (count > maxCount) {
34            resList.clear();
35            resList.add(root.val);
36            maxCount = count;
37        } else if (count == maxCount) { // 如果遇到众数值相等时,则将其节点值加入其中
38            resList.add(root.val);
39        }
40        pre = root; // 更新前一节点pre到当前节点
41        // 右:更新当前节点向右遍历
42        traversal(root.right);
43    }
44}

3. 复杂度分析

时间复杂度:O(n).遍历整棵树.

空间复杂度:O(n).原理同上一题:LeetCode:530.二叉搜索树的最小绝对差


LeetCode:236. 二叉树的最近公共祖先

236. 二叉树的最近公共祖先 - 力扣(LeetCode)


1.思路

递归法:需要返回节点值——>因此需要回溯返回左右节点匹配的值——>遍历顺序为后序(返回中节点的操作值)——>确定终止条件:跟节点为空||根节点等于p或q


2. 代码实现

 1class Solution {
 2    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
 3        // 确定递归函数的参数及返回值
 4        if (root == null || root == p || root == q) {
 5            return root;
 6        }
 7        // 记录返回值,使用回溯;回溯则使用后序遍历
 8        // 左:
 9        TreeNode left = lowestCommonAncestor(root.left, p, q);
10        // 右
11        TreeNode right = lowestCommonAncestor(root.right, p, q);
12        // 中:做回溯操作...
13        if (left == null && right == null) { // 左右节点均为null,不存在最小公共祖先,返回null即可
14            return null;
15        } else if (left != null && right == null) { // 左节点存在一个p或q,右节点为空,返回左节点即可
16            return left;
17        } else if (left == null && right != null) { // 右节点存在一个p或q,左节点为null,返回右节点即可
18            return right;
19        } else {
20            return root; // 左右节点均不为空,则该节点即为p和q的最小公共祖先,返回即可
21        }
22    }
23}

3. 复杂度分析

时间复杂度:O(n).最大调用所有节点.

空间复杂度:O(n).最大坏情况为链表.


相关文章
|
1月前
|
算法
分享一些提高二叉树遍历算法效率的代码示例
这只是简单的示例代码,实际应用中可能还需要根据具体需求进行更多的优化和处理。你可以根据自己的需求对代码进行修改和扩展。
|
1月前
|
存储 缓存 算法
如何提高二叉树遍历算法的效率?
选择合适的遍历算法,如按层次遍历树时使用广度优先搜索(BFS),中序遍历二叉搜索树以获得有序序列。优化数据结构,如使用线索二叉树减少空指针判断,自定义节点类增加辅助信息。利用递归与非递归的特点,避免栈溢出问题。多线程并行遍历提高速度,注意线程安全。缓存中间结果,避免重复计算。预先计算并存储信息,提高遍历效率。综合运用这些方法,提高二叉树遍历算法的效率。
58 5
|
2月前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
119 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
1月前
|
机器学习/深度学习 JSON 算法
二叉树遍历算法的应用场景有哪些?
【10月更文挑战第29天】二叉树遍历算法作为一种基础而重要的算法,在许多领域都有着不可或缺的应用,它为解决各种复杂的问题提供了有效的手段和思路。随着计算机科学的不断发展,二叉树遍历算法也在不断地被优化和扩展,以适应新的应用场景和需求。
43 0
|
1月前
|
分布式计算 Java 开发工具
阿里云MaxCompute-XGBoost on Spark 极限梯度提升算法的分布式训练与模型持久化oss的实现与代码浅析
本文介绍了XGBoost在MaxCompute+OSS架构下模型持久化遇到的问题及其解决方案。首先简要介绍了XGBoost的特点和应用场景,随后详细描述了客户在将XGBoost on Spark任务从HDFS迁移到OSS时遇到的异常情况。通过分析异常堆栈和源代码,发现使用的`nativeBooster.saveModel`方法不支持OSS路径,而使用`write.overwrite().save`方法则能成功保存模型。最后提供了完整的Scala代码示例、Maven配置和提交命令,帮助用户顺利迁移模型存储路径。
|
2月前
|
存储 算法 关系型数据库
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
这篇文章主要介绍了多路查找树的基本概念,包括二叉树的局限性、多叉树的优化、B树及其变体(如2-3树、B+树、B*树)的特点和应用,旨在帮助读者理解这些数据结构在文件系统和数据库系统中的重要性和效率。
32 0
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
|
2月前
|
存储 算法 搜索推荐
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
这篇文章主要介绍了顺序存储二叉树和线索化二叉树的概念、特点、实现方式以及应用场景。
36 0
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
|
18天前
|
算法
基于WOA算法的SVDD参数寻优matlab仿真
该程序利用鲸鱼优化算法(WOA)对支持向量数据描述(SVDD)模型的参数进行优化,以提高数据分类的准确性。通过MATLAB2022A实现,展示了不同信噪比(SNR)下模型的分类误差。WOA通过模拟鲸鱼捕食行为,动态调整SVDD参数,如惩罚因子C和核函数参数γ,以寻找最优参数组合,增强模型的鲁棒性和泛化能力。
|
24天前
|
机器学习/深度学习 算法 Serverless
基于WOA-SVM的乳腺癌数据分类识别算法matlab仿真,对比BP神经网络和SVM
本项目利用鲸鱼优化算法(WOA)优化支持向量机(SVM)参数,针对乳腺癌早期诊断问题,通过MATLAB 2022a实现。核心代码包括参数初始化、目标函数计算、位置更新等步骤,并附有详细中文注释及操作视频。实验结果显示,WOA-SVM在提高分类精度和泛化能力方面表现出色,为乳腺癌的早期诊断提供了有效的技术支持。
|
4天前
|
供应链 算法 调度
排队算法的matlab仿真,带GUI界面
该程序使用MATLAB 2022A版本实现排队算法的仿真,并带有GUI界面。程序支持单队列单服务台、单队列多服务台和多队列多服务台三种排队方式。核心函数`func_mms2`通过模拟到达时间和服务时间,计算阻塞率和利用率。排队论研究系统中顾客和服务台的交互行为,广泛应用于通信网络、生产调度和服务行业等领域,旨在优化系统性能,减少等待时间,提高资源利用率。