【优先队列-最小堆法,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);
        }
    }
}
全部评论

相关推荐

2024-12-21 10:42
已编辑
江西软件职业技术大学 Java
新宿站不停:该提升学历就提升学历,菜了就多练。没事找牛马公司虐自己是吧? 谁没事说自己“经验少”,这不自己把自己塞剎鼻hr嘴里找🐴吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务