题解 | #二叉树之寻找第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,就移除堆顶元素
  • 最后小顶堆堆顶元素就是所求答案
  • #二叉树的遍历##优先队列的应用#
    线性表基础 文章被收录于专栏

    链表、递归、栈

    全部评论

    相关推荐

    点赞 收藏 评论
    分享
    牛客网
    牛客企业服务