272. Closest Binary Search Tree Value II

Given a non-empty binary search tree and a target value, find k values in the BST that are closest to the target.

Note:
Given target value is a floating point.
You may assume k is always valid, that is: k ≤ total nodes.
You are guaranteed to have only one unique set of k values in the BST that are closest to the target.
Follow up:
Assume that the BST is balanced, could you solve it in less than O(n) runtime (where n = total nodes)?

一刷
题解:
我们用两个栈,全部采用inorder访问树。
一个栈从小到大,存储<= target的节点
一个栈由大到小,存储>target的节点。
然后比较两个栈头的值,存储距离较小的点,一直进行k次。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> closestKValues(TreeNode root, double target, int k) {
        List<Integer> res = new ArrayList<>();
        
        Stack<Integer> s1 = new Stack<>();//predecessors
        Stack<Integer> s2 = new Stack<>();//successors
        if(root == null) return res;
        
        inorder(root, target, false, s1);//ascending, and store the node with value lower than or equal to target
        inorder(root, target, true, s2);//descending
        while(k-->0){
            if(s1.isEmpty()) res.add(s2.pop());
            else if(s2.isEmpty()) res.add(s1.pop());
            else if(Math.abs(s1.peek() - target)<Math.abs(s2.peek() - target))
                res.add(s1.pop());
            else res.add(s2.pop());
        }
        return res;
    }
    
    private void inorder(TreeNode root, double target, boolean reverse, Stack<Integer> stack){
        if(root == null) return;
        inorder(reverse? root.right:root.left, target, reverse, stack);
        // early terminate, no need to traverse the whole tree
        if((reverse && root.val<=target) || (!reverse && root.val>target)) return;
        // track the value of current node
        stack.push(root.val);
        inorder(reverse? root.left : root.right, target, reverse, stack);
    }
}

二刷
题解:思路同上。但是我们这次用两个array和index来模拟上述行为。
inorder traverse,
如果root.val小于target, append在smaller尾部
否则,append在bigger尾部
所以smaller尾部和bigger的头部更满足要求。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public List<Integer> closestKValues(TreeNode root, double target, int k) {
        List<Integer> smaller = new ArrayList<>();
        List<Integer> bigger = new ArrayList<>();
        //inorder
        inorder(root, target, smaller, bigger);
        int sIndex = smaller.size()-1;
        int bIndex = 0;
        List<Integer> res = new ArrayList<>(k);
        int index = 0;
        while(res.size()<k){
            if(sIndex<0){
                res.add(bigger.get(bIndex++));
            }else if(bIndex == bigger.size()){
                res.add(smaller.get(sIndex--));
            }else{
                if(Math.abs(smaller.get(sIndex) - target) < Math.abs(bigger.get(bIndex) - target)){
                    res.add(smaller.get(sIndex--));
                }else res.add(bigger.get(bIndex++));
            }
        }
        return res;
    }
    
    private void inorder(TreeNode root, double target, List<Integer> smaller, List<Integer> bigger){
        if(root == null) return;
        inorder(root.left, target, smaller, bigger);
        if(root.val<target) smaller.add(root.val);
        else bigger.add(root.val);
        inorder(root.right, target, smaller, bigger);
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Given a non-empty binary search tree and a target value, ...
    matrxyz阅读 2,540评论 0 0
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 博瑞智赵亮 首先,现在是大环境使然,不让孩子接触手机,断绝网络,几乎是不可能的。我们家长要紧跟潮流,顺应孩子心理。...
    玲03阅读 1,053评论 1 1
  • 你怯懦地祈助的 别人的著作救不了你 你不是别人, 此刻你正身处 自己的脚步编织起的迷宫的中心之地 ...
    阿清阅读 3,359评论 0 2
  • /#幸福是需要修出来的~每天进步1%~幸福实修09班~21~邹迪 20170819(33/30)09班 【幸福三朵...
    猫妈Kubaoer阅读 1,488评论 1 0