千家信息网

如何实现二叉搜索树节点最小距离

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本篇内容主要讲解"如何实现二叉搜索树节点最小距离",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何实现二叉搜索树节点最小距离"吧!给你一个二叉搜索树的根节
千家信息网最后更新 2025年01月19日如何实现二叉搜索树节点最小距离

本篇内容主要讲解"如何实现二叉搜索树节点最小距离",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何实现二叉搜索树节点最小距离"吧!

给你一个二叉搜索树的根节点 root ,返回树中任意两不同节点值之间的最小差值 。

示例 1:

输入:root = [4,2,6,1,3]

输出:1

示例 2:

输入:root = [1,0,48,null,null,12,49]

输出:1

提示:

树中节点数目在范围 [2, 100] 内

0 <= Node.val <= 10^5

题目分析:

1,根据二叉搜索树的性质,我们可以采取中序遍历的方式获取排序后的结果

2,由于节点的值在[0,10^5]范围内,节点值的差值在[-10^5-1,10^5+1]范围内

3,需要用一个pre记录前驱节点

4,针对二叉搜索树类型的题目,通过遍历可以得到有序的数列,然后可以求差值

5,根据题意,默认是升序

代码实现

/** * Definition for a binary tree node. * type TreeNode struct { *     Val int *     Left *TreeNode *     Right *TreeNode * } */func minDiffInBST(root *TreeNode) int {    _,diff:=bst(root,-100001,100001)    return diff}
func bst(root*TreeNode,pre,diff int)(int,int){ if root==nil{ return pre,diff } pre,diff=bst(root.Left,pre,diff) if root.Val-pre diff=root.Val-pre } pre=root.Val pre,diff=bst(root.Right,pre,diff) return pre,diff}

解法二:

/** * Definition for a binary tree node. * type TreeNode struct { *     Val int *     Left *TreeNode *     Right *TreeNode * } */  var a[]intfunc minDiffInBST(root *TreeNode) int {    a=nil    visit(root)    min:=100    for i:=0;i        if min>a[i+1]-a[i]{            min=a[i+1]-a[i]        }    }    return min}
func visit(root *TreeNode){ if root==nil{ return } visit(root.Left) a=append(a,root.Val) visit(root.Right)}

到此,相信大家对"如何实现二叉搜索树节点最小距离"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

0