170 похожих чатов

@Antoshkka Добрый вечер. Я пытался выяснить для себя какой-то реальный

пример использования кучи в проде, а именно, в каких случаях люди осознанно использовали именно этот АТД как лучший выбор, и один из инсайдеров Яндекса мне написал, что priority_queue встречается в коде Яндекс Такси 5 раз.
Антон, если есть возможность, пожалуйста, напишите пару кейсов, почему выбирали именно кучу? Именно, какие особенности решаемой задачи продиктовали такой выбор?
Надеюсь, просьба не обременительная.
PS Участникам сообщества, которые захотят предложить мне использовать Гугл - пожалуйста, не беспокойтесь. С академическими примерами использования кучи я знаком, я ищу примера использования в бизнес-приложении.

9 ответов

15 просмотров

Про бизнес не скажу, но могу поделиться опытом с олимпиад: priority_queue регулярно работает тупо в полтора-два раза быстрее set. Возможно, за счёт меньшего выделения памяти, возможно, за счёт более простой структуры, а может всё вместе.

Egor Suvorov
Про бизнес не скажу, но могу поделиться опытом с о...

в олимпиадах наверное лучше всё в хеш умещается)) задачи то обычно небольшие

Kelbon
в олимпиадах наверное лучше всё в хеш умещается)) ...

Там обычно 10^5 элементов pair<int, int>, это почти мегабайт. Так что в L3 влезть может, а вот в L1/L2 — уже нет.

Kelbon
прямо во всех задачах pair<int int> 10^5?)

priority_queue обычно возникает в районе алгоритма Дейкстры. Там 10^5 — стандартное ограничение для графов, для Дейкстры в куче обычно хранится расстояние до вершины и её номер — отсюда пара.

Да хоть банальные таймеры доставать на каждой итерации main loop нужна приоритетная очередь

Ignat Loskutov
Да хоть банальные таймеры доставать на каждой итер...

Приоритетная очередь это ж не обязательно heap.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта