给你一个二叉搜索树的根节点 root
,返回 树中任意两不同节点值之间的最小差值 。
差值是一个正数,其数值等于两值之差的绝对值。
示例 1:
代码语言:javascript复制输入:root = [4,2,6,1,3]
输出:1
示例 2:
代码语言:javascript复制输入:root = [1,0,48,null,null,12,49]
输出:1
考虑对升序数组
求任意两个元素之差的绝对值的最小值,答案一定为相邻两个元素之差的最小值,即
其中
为数组
的长度。其他任意间隔距离大于等于
的下标对(i,j)的元素之差一定大于下标对 (i,i 1)的元素之差,故不需要再被考虑。
回到本题,本题要求二叉搜索树任意两节点差的绝对值的最小值,而我们知道二叉搜索树有个性质为二叉搜索树中序遍历得到的值序列是递增有序的,因此我们只要得到中序遍历后的值序列即能用上文提及的方法来解决。
朴素的方法是经过一次中序遍历将值保存在一个数组中再进行遍历求解,我们也可以在中序遍历的过程中用
变量保存前驱节点的值,这样即能边遍历边更新答案,不再需要显式创建数组来保存,需要注意的是
的初始值需要设置成任意负数标记开头,下文代码中设置为-1。
二叉树的中序遍历有多种方式,包括递归、栈、Morris 遍历等,读者可选择自己最擅长的来实现。