二叉搜索树的最小绝对差
题目详细:LeetCode.530
这道题使我第一次了解到二叉树的双指针遍历法,详细可以先查看卡哥的讲解视频:《代码随想录 — 二叉搜索树中的众数》
利用二叉搜索树的特点:
- 中序遍历二叉搜索树得到一个有序序列
- 计算序列中相邻的每一个数的差值,记录最小绝对值差
但我们可以发现,如果我们可以在遍历过程中去计算相邻的两个数的差值,那么速度将提升很多,对于序列是否有序这一点似乎并不是特别重要,只是二叉搜索树赋予了它这一特点。
那么我们可以利用双指针法:
- 定义一个指针 pre 指向当前节点的前一个节点
- 按照左中右的顺序,深度优先遍历树的节点
- 若 pre 为空,则说明当前节点为叶子节点,不存在前一个节点
- 若 pre 不为空,则计算前一个节点与当前节点的绝对差值,利用全局变量记录一个最小值结果
- 注意更新前一个节点 pre = cur
Java解法(递归):
class Solution {
public int ans = Integer.MAX_VALUE;
public TreeNode pre = null;
public int getMinimumDifference(TreeNode root) {
this.dfs(root);
return ans;
}
public void dfs(TreeNode cur){
if(null == cur) return;
this.dfs(cur.left);
if(null != this.pre)
文章介绍了如何利用二叉搜索树的特性,结合双指针法解决最小绝对差问题和找众数问题。对于最小绝对差,通过中序遍历和记录前一个节点,能有效计算相邻节点的差值。对于众数,同样使用中序遍历和双指针法跟踪出现频率,实现高效查找。此外,还讨论了找到二叉树中两个节点的最近公共祖先的递归策略。
最低0.47元/天 解锁文章
288

被折叠的 条评论
为什么被折叠?



