题解 | #二叉树之寻找第k大#

二叉树之寻找第k大

https://www.nowcoder.com/practice/8e5f73fa3f1a407eb7d0b0d7a105805e

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 kthLargest (TreeNode root, int k) {
        // write code here
        Queue<Integer> queue = new PriorityQueue<>();
        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,就移除堆顶元素
  • 最后小顶堆堆顶元素就是所求答案
  • #二叉树的遍历##优先队列的应用#
    线性表基础 文章被收录于专栏

    链表、递归、栈

    全部评论

    相关推荐

    面试了几家,全程问项目,八股一点都不问,可惜准备了这么久
    独角仙梦境:现在感觉问八股像是中场休息一样的,问几个八股放松一下再上强度
    点赞 评论 收藏
    分享
    05-09 12:23
    已编辑
    华南理工大学 Java
    野猪不是猪🐗:给他装的,双九+有实习的能看的上这种厂我直接吃⑨✌们拿它练练面试愣是给他整出幻觉了
    点赞 评论 收藏
    分享
    我面试,她问我有女朋友没
    不太迷人的反派_:不过对象,还会结合你老家,意向城市等等,看你是否稳定。哥们,别多想
    点赞 评论 收藏
    分享
    评论
    点赞
    收藏
    分享

    创作者周榜

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