求问 leetcode 上的一道 BST 题。

2019-05-26 16:37:01 +08:00
 Godjack

我的代码如下

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public int getMinimumDifference(TreeNode root) {
        TreeNode res = new TreeNode(Integer.MAX_VALUE);
        TreeNode pre = null;
        inOrder(root, res, pre);
        return res.val;
    }
    
    private void inOrder(TreeNode node, TreeNode k, TreeNode pre) {
        if (node==null) return;
        inOrder(node.left, k, pre);
        if (pre!=null) k.val = Math.min(k.val, node.val-pre.val);
        pre = node;
        inOrder(node.right, k, pre);
    }
    
}

讨论区网友的代码如下

class Solution {
    
    // do a inorder traversal
    // compare current val with previous val
    // update answer
    
    private Integer prev;
    private int ans;
    
    public int getMinimumDifference(TreeNode root) {
        ans = Integer.MAX_VALUE;
        inorder(root);
        return ans;
    }
     
    private void inorder(TreeNode root) {
        if (root == null) return;
        inorder(root.left);
        if (prev != null)
            ans = Math.min(ans, root.val - prev);
        prev = root.val;
        inorder(root.right);
    }
}

部分测试通不过,自己实在找不出错误了,希望大家能帮忙看看。感激不尽

2764 次点击
所在节点    Java
14 条回复
springz
2019-05-26 16:50:22 +08:00
xiang578
2019-05-26 16:59:53 +08:00
建议把题目发一下,不能都不知道是什么。
wallriding
2019-05-26 17:01:58 +08:00
至少写个题号吧
Godjack
2019-05-26 17:32:18 +08:00
Godjack
2019-05-26 17:32:41 +08:00
@wallriding 不好意思,我 sb 了,题号是 530,
iEverX
2019-05-26 18:27:02 +08:00
区别就是 prev,你的代码里不是全局的,退栈之后就没了
Godjack
2019-05-26 19:00:42 +08:00
@iEverX 谢谢你的回复, 但是 pre 和 inOrder()都是在 getMinimumDifference()中,只要 getMinimumDifference()函数没结束,inOrder()退栈之后应该 pre 还在吧,而且我把 pre 和 res 定义为类的变量结果也不对...
iEverX
2019-05-26 19:22:08 +08:00
@Godjack #7 不清楚你怎么改的。你现在的代码,是没有办法判断左子树的,只能判断右子树。给你个例子。
14 2 # 1 13
ksedz
2019-05-26 19:30:45 +08:00
是 prev 的问题,没有全局更新
你的答案里遍历完一个子树,prev 的更新没有回传到上一层调用

比如
[10,5,null,1,8]
Godjack
2019-05-26 21:26:15 +08:00
@ksedz 懂了,谢谢你,指针没理解好。
Godjack
2019-05-26 21:27:48 +08:00
@iEverX 虽然当时没理解你的意思,但是还是谢谢你的回复,现在我已经懂了。
jc89898
2019-05-26 22:26:18 +08:00
@Godjack java 有指针?
Godjack
2019-05-27 07:40:57 +08:00
@jc89898 呃,我这么说不严谨。
stebest
2019-05-27 10:21:26 +08:00
LeetCode CN 版的里面有题解

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/567797

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX