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

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

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

11 ответов

27 просмотров

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

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
Вроде не обязательно сортирует

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Ребят в СИ можно реализовать ООП?
Николай
33
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
2
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта