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

Добрый день. Почему вот такая запись может выдавать ошибку?

priority_queue<pair<int, int>, greater<pair<int, int>>> tmp;
Возникает ошибка
"Ошибка C2794 value_type: не является прямым или косвенным базовым классом для "std::greater<std::pair<int,int>>"
"
Не понимаю почему не верно, если по умолчанию, если я указываю функцию сравнения, то там по умолчанию less, он же как-то заполняется и работает

11 ответов

30 просмотров

второй параметр шаблона - тип контейнера

jon-pedro Автор вопроса
Егор (Дима)
второй параметр шаблона - тип контейнера

точно, теперь тогда я совсем не понял как с этим контейнером работать. Для чего нужен 2 параметр. Смотрю доку и не совсем понимаю для чего этот параметр нужен. Первый это тип хранимых значений, а второе тип базового контейнера. Типо идея в том, что priority_queue тупо укладывает данные в контейнер и вызывает sort?

jon pedro
точно, теперь тогда я совсем не понял как с этим к...

что она внутри делает я не знаю, и сомневаюсь что оно где-то в стандарте описано. Но в целом да, приорити куе - адаптер

jon pedro
точно, теперь тогда я совсем не понял как с этим к...

этого не достаточно https://en.cppreference.com/w/cpp/container/priority_queue ?

jon-pedro Автор вопроса
Anatoly Shirokov
этого не достаточно https://en.cppreference.com/w/...

ну от части лишь. Возникает какой-то конфликт в голове с выбором контейнера. Вот есть map, если читать доку, то на оператор [] "No iterators or references are invalidated. ". Т.е в целом та можно было бы по тому же принципу и хранить, но как я понимаю с priority_queue я могу выбрать, инвалидировать или не инвалидировать указатели/итераторы

jon pedro
точно, теперь тогда я совсем не понял как с этим к...

Просто на основе контейнера (2) строит очередь с приоритетом, приоритет задается компоратором

jon pedro
ну от части лишь. Возникает какой-то конфликт в го...

это адаптер над вектором или декой, при добавлении он сортирует вектор или деку согласно переданного компоратора (по умолчанию greater)

jon-pedro Автор вопроса
Anatoly Shirokov
это адаптер над вектором или декой, при добавлении...

я просто не совсем понимаю для чего выбирать адаптер, когда можно было бы реализовать как в map. Асимптитока же добавления элемента и удаления идентична в обоих контейнерах.

Maus Grau
Вроде не обязательно сортирует

асимптотика там логарифм, и как иначе поддерживать приоритет в векторе?

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта