题解 | #第k轻的牛牛#

第k轻的牛牛

https://www.nowcoder.com/practice/d3b31f055b1640d9b10de0a6f2b8e6f3

import java.util.*;

/*
 * public class TreeNode {
 *   int val = 0;
 *   TreeNode left = null;
 *   TreeNode right = null;
 *   public TreeNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param root TreeNode类 
     * @param k int整型 
     * @return int整型
     */
    public int kthLighest (TreeNode root, int k) {
        // write code here
        Queue<Integer> queue = new PriorityQueue<>((o1, o2) -> o2 - o1);
        preOrder(root, queue, k);
        return queue.peek();
    }
    private void preOrder(TreeNode root, Queue<Integer> queue, int k) {
        if (root == null) return;
        queue.offer(root.val);
        if (queue.size() > k) queue.poll();
        preOrder(root.left, queue, k);
        preOrder(root.right, queue, k);
    }
}
  • 根据题意要找第k小的,可以想到用大顶堆来维护,这里使用Java自带的 PriorityQueue
  • 任意选择一种二叉树的遍历方式(前中后都可以),元素添加到 queue 后,如果queue的大小超过k,就移除堆顶元素
  • 最后大顶堆堆顶元素就是所求答案
#二叉树的遍历##优先队列的应用#
线性表基础 文章被收录于专栏

链表、递归、栈

全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
07-09 18:33
门头沟学院 Java
这么逆天每年都有人去???&nbsp;填多益网申就是大型的服从性测试
鲁大牛:辅导员在群里发了这个公司我就申了一下。网申居然要写当场开摄像头写两篇不少于三百字的作文。太逆天了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务