【优先队列-最小堆法,beat 97%】 | #二叉搜索树的第k个结点#

二叉搜索树的第k个结点

http://www.nowcoder.com/practice/ef068f602dde4d28aab2b210e859150a

思路

核心就是得熟悉优先队列比较器的改写方法
① 建立最小堆存储节点:根据节点val升序排列;
② 输出结果。

代码

import java.util.*;
public class Solution {
    // 建立最小堆存储节点:根据节点val升序排列
    PriorityQueue<TreeNode> heap = new PriorityQueue<>(new Comparator<TreeNode>(){
        public int compare(TreeNode n1,TreeNode n2){
            return n1.val-n2.val; // 根据节点val升序排列
        }
    });
    // 主函数
    TreeNode KthNode(TreeNode pRoot, int k) {
        if(pRoot == null || k < 1) return null;
        // 1、保存所有节点
        saveNode(pRoot);
        TreeNode res = pRoot;
        // 2、输出结果
        while(k-- > 0) res = heap.poll();
        return res;
    }
    // 保存节点
    private void saveNode(TreeNode pRoot){
        if(pRoot != null){
            heap.add(pRoot);
            saveNode(pRoot.left);
            saveNode(pRoot.right);
        }
    }
}
全部评论

相关推荐

明明就不饿:看不懂你到底会啥,什么岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4453次浏览 78人参与
# 找AI工作可以去哪些公司? #
10086次浏览 314人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15694次浏览 229人参与
# 你的实习产出是真实的还是包装的? #
20825次浏览 346人参与
# 从事AI岗需要掌握哪些技术栈? #
9809次浏览 390人参与
# 春招至今,你的战绩如何? #
67740次浏览 599人参与
# 厦门银行科技岗值不值得投 #
8237次浏览 188人参与
# AI面会问哪些问题? #
29127次浏览 632人参与
# 你做过最难的笔试是哪家公司 #
35940次浏览 313人参与
# 中国电信笔试 #
32390次浏览 301人参与
# 金三银四,你的春招进行到哪个阶段了? #
22563次浏览 284人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
341221次浏览 2176人参与
# 同bg的你秋招战况如何? #
212267次浏览 1121人参与
# 哪些公司真双非友好? #
69817次浏览 289人参与
# 如何准备秋招 #
78324次浏览 868人参与
# 阿里笔试 #
179436次浏览 1324人参与
# 应届生被毁约被毁意向了怎么办 #
63349次浏览 305人参与
# 机械人避雷的岗位/公司 #
62727次浏览 393人参与
# 小马智行求职进展汇总 #
25151次浏览 80人参与
# 第一份工作一定要去大厂吗 #
15204次浏览 123人参与
# 担心入职之后被发现很菜怎么办 #
291429次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26323次浏览 310人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务