算法训练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).最大坏情况为链表.


相关文章
|
10月前
|
机器学习/深度学习 存储 算法
解锁文件共享软件背后基于 Python 的二叉搜索树算法密码
文件共享软件在数字化时代扮演着连接全球用户、促进知识与数据交流的重要角色。二叉搜索树作为一种高效的数据结构,通过有序存储和快速检索文件,极大提升了文件共享平台的性能。它依据文件名或时间戳等关键属性排序,支持高效插入、删除和查找操作,显著优化用户体验。本文还展示了用Python实现的简单二叉搜索树代码,帮助理解其工作原理,并展望了该算法在分布式计算和机器学习领域的未来应用前景。
|
7月前
|
存储 监控 算法
公司内部网络监控中的二叉搜索树算法:基于 Node.js 的实时设备状态管理
在数字化办公生态系统中,公司内部网络监控已成为企业信息安全管理体系的核心构成要素。随着局域网内终端设备数量呈指数级增长,实现设备状态的实时追踪与异常节点的快速定位,已成为亟待解决的关键技术难题。传统线性数据结构在处理动态更新的设备信息时,存在检索效率低下的固有缺陷;而树形数据结构因其天然的分层特性与高效的检索机制,逐渐成为网络监控领域的研究热点。本文以二叉搜索树(Binary Search Tree, BST)作为研究对象,系统探讨其在公司内部网络监控场景中的应用机制,并基于 Node.js 平台构建一套具备实时更新与快速查询功能的设备状态管理算法框架。
284 3
|
9月前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
312 10
 算法系列之数据结构-二叉树
|
9月前
|
算法 Java
算法系列之数据结构-二叉搜索树
二叉查找树(Binary Search Tree,简称BST)是一种常用的数据结构,它能够高效地进行查找、插入和删除操作。二叉查找树的特点是,对于树中的每个节点,其左子树中的所有节点都小于该节点,而右子树中的所有节点都大于该节点。
391 22
|
9月前
|
存储 监控 算法
基于 PHP 二叉搜索树算法的内网行为管理机制探究
在当今数字化网络环境中,内网行为管理对于企业网络安全及高效运营具有至关重要的意义。它涵盖对企业内部网络中各类行为的监测、分析与管控。在内网行为管理技术体系里,算法与数据结构扮演着核心角色。本文将深入探究 PHP 语言中的二叉搜索树算法于内网行为管理中的应用。
139 4
|
10月前
|
存储 算法 Java
解锁“分享文件”高效密码:探秘 Java 二叉搜索树算法
在信息爆炸的时代,文件分享至关重要。二叉搜索树(BST)以其高效的查找性能,为文件分享优化提供了新路径。本文聚焦Java环境下BST的应用,介绍其基础结构、实现示例及进阶优化。BST通过有序节点快速定位文件,结合自平衡树、多线程和权限管理,大幅提升文件分享效率与安全性。代码示例展示了文件插入与查找的基本操作,适用于大规模并发场景,确保分享过程流畅高效。掌握BST算法,助力文件分享创新发展。
|
10月前
|
监控 算法 安全
关于公司电脑桌面监控中 PHP 二叉搜索树算法的深度剖析
在现代企业管理中,公司电脑桌面监控系统通过二叉搜索树(BST)算法保障信息安全和提高效率。本文探讨PHP中的BST在监控场景的应用,包括节点定义、插入与查找操作,并展示如何管理时间戳数据,以快速查询特定时间段内的操作记录。BST的高效性使其成为处理复杂监控数据的理想选择。
140 2
|
11月前
|
存储 算法 安全
U 盘管控情境下 Python 二叉搜索树算法的深度剖析与探究
在信息技术高度发达的今天,数据安全至关重要。U盘作为常用的数据存储与传输工具,其管控尤为关键。本文探讨Python中的二叉搜索树算法在U盘管控中的应用,通过高效管理授权U盘信息,防止数据泄露,保障信息安全。二叉搜索树具有快速插入和查找的优势,适用于大量授权U盘的管理。尽管存在一些局限性,如树结构退化问题,但通过优化和改进,如采用自平衡树,可以有效提升U盘管控系统的性能和安全性。
183 3
|
11月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
537 3
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
276 0

热门文章

最新文章