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,就移除堆顶元素
  • 最后大顶堆堆顶元素就是所求答案