2

假设我们要根据值对 hashmap 进行排序。我们实现了一个带有比较器的 priorityQueue 来做到这一点。结果,生成的 pq 是从索引 0 到结尾从最大到最小排序。

这是代码:

PriorityQueue<Map.Entry<Integer, Integer>> pq = new PriorityQueue<Map.Entry<Integer, Integer>>(
                new Comparator<Map.Entry<Integer, Integer>>() {
                    @Override
                    public int compare(Entry<Integer, Integer> o1, Entry<Integer, Integer> o2) {
                        return o2.getValue() - o1.getValue();
                    }
                });

但是,有人说它是 maxheap,我知道 heap 只是父值大于子值,但我不明白为什么它是 maxheap?它只是在priorityQueue中实现比较器?这与堆有什么关系?

4

1 回答 1

2

java中优先级队列的内部结构是堆。
此比较器将用于与优先级队列中的父值进行比较。

于 2016-07-21T04:18:08.260 回答