Похожие вопросы:
- Java PriorityQueue с фиксированным размером
- Как использовать PriorityQueue?
- получить индексы n наименьших элементов в массиве
- Scala: Есть ли способ использовать PriorityQueue, как в Java?
У меня есть очень большой набор данных (более 5 миллионов элементов), и мне нужно получить N наибольших элементов. Самый естественный способ сделать это - использовать очередь кучи/приоритета хранить только верхние N элементов. Существует несколько хороших реализаций очереди приоритетов для JVM (Scala/Java), а именно:
Первые 2 хороши, но они сохраняют все элементы, которые в моем случае дают критические издержки памяти. В-третьих (реализация Lucene) не имеет такого недостатка, но, как я вижу из документации, он также не поддерживает пользовательский компаратор, что делает его бесполезным для меня.
Итак, мой вопрос: существует ли  PriorityQueue реализация с  фиксированной емкостью и  специализированным компаратором?
UPD. Наконец, я создал свою собственную реализацию на основе ответа Питера:
public class FixedSizePriorityQueue<E> extends TreeSet<E> {
    private int elementsLeft;
    public FixedSizePriorityQueue(int maxSize) {
        super(new NaturalComparator());
        this.elementsLeft = maxSize;
    }
    public FixedSizePriorityQueue(int maxSize, Comparator<E> comparator) {
        super(comparator);
        this.elementsLeft = maxSize;
    }
    /**
     * @return true if element was added, false otherwise
     * */
    @Override
    public boolean add(E e) {
        if (elementsLeft == 0 && size() == 0) {
            // max size was initiated to zero => just return false
            return false;
        } else if (elementsLeft > 0) {
            // queue isn't full => add element and decrement elementsLeft
            boolean added = super.add(e);
            if (added) {
                elementsLeft--;
            }
            return added;
        } else {
            // there is already 1 or more elements => compare to the least
            int compared = super.comparator().compare(e, this.first());
            if (compared == 1) {
                // new element is larger than the least in queue => pull the least and add new one to queue
                pollFirst();
                super.add(e);
                return true;
            } else {
                // new element is less than the least in queue => return false
                return false;
            }
        }
    }
}
(где NaturalComparator взято из этого вопроса)
