783_二叉搜索树节点最小距离

简介: 783_二叉搜索树节点最小距离

783_二叉搜索树节点最小距离


package 二叉树.二叉搜索树;
/**
 * https://leetcode-cn.com/problems/minimum-distance-between-bst-nodes/
 * @author Huangyujun
 *
 */
public class _783_二叉搜索树节点最小距离 {
    //找到二叉树中两个值的差最小(拿到数据~遍历),如何加快拿到“最小的”数据,先将拿到的数据进行排序处理(咱选择升序降序都ok)
    //经过处理(升序)的数据,可以直接两个连续挨着近的数据可能是最小
    //过程的数据要注意一个细节:差,是从拥有了两个数据开始才诞生的,但是遍历一开始才有一个数据,咱需要先记录下来(作为第一个数据,留个下个数据比较操作之类的)
    int ans = 0;
    int pre = 0;
    public int minDiffInBST(TreeNode root) {
        ans = Integer.MAX_VALUE;
        pre = -1;
        inorder(root);
        return ans;
    }
    public void inorder(TreeNode root) {
        if(root == null)    return;
        inorder(root.left);
        //拿到数据,
        if(pre == -1) {
            pre = root.val;
        }else {
            ans = Math.min(ans, root.val - pre);
            pre = root.val;
        }
        inorder(root.right);
    }
}
目录
相关文章
|
索引
【Leetcode -1721.交换链表中的节点 -2058.找出临界点之间的最小和最大距离】
【Leetcode -1721.交换链表中的节点 -2058.找出临界点之间的最小和最大距离】
53 0
26_二叉搜索树的最小绝对差
26_二叉搜索树的最小绝对差
12_二叉树的最小深度
12_二叉树的最小深度
|
7月前
【树 - 平衡二叉树(AVL)】F(n)=F(n-1)+F(n-2)+1 这个类似于一个递归的数列,1是根节点,F(n-1)是左子树的节点数量,F(n-2)是右子树的节点数量
【树 - 平衡二叉树(AVL)】F(n)=F(n-1)+F(n-2)+1 这个类似于一个递归的数列,1是根节点,F(n-1)是左子树的节点数量,F(n-2)是右子树的节点数量
|
8月前
|
算法 前端开发
图中的最长环
图中的最长环
64 0
|
8月前
|
C++
二叉树的最小深度(C++)
二叉树的最小深度(C++)
39 1
|
机器学习/深度学习 算法 测试技术
C++二分算法: 找出第 K 小的数对距离
C++二分算法: 找出第 K 小的数对距离
二叉树——530.二叉搜索树的最小绝对差
本专栏按照数组—链表—哈希—字符串—栈与队列—二叉树—回溯—贪心—动态规划—单调栈的顺序刷题,采用代码随想录所给的刷题顺序,一个正确的刷题顺序对算法学习是非常重要的,希望对大家有帮助
二叉树——530.二叉搜索树的最小绝对差
二叉树——111. 二叉树的最小深度
本专栏按照数组—链表—哈希—字符串—栈与队列—二叉树—回溯—贪心—动态规划—单调栈的顺序刷题,采用代码随想录所给的刷题顺序,一个正确的刷题顺序对算法学习是非常重要的,希望对大家有帮助
二叉树——111. 二叉树的最小深度
Day16——二叉树的最大深度、二叉树的最小深度、完全二叉树的节点个数
Day16——二叉树的最大深度、二叉树的最小深度、完全二叉树的节点个数
131 0