Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915

std::priority_queue - очередь с приоритетом

06.10.2023, 18:11. Показов 688. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте,


Подскажите пожалуйста, как работает std:riority_queue внутри ?

То есть я понимаю, что это некий адаптер к std::vector и std::deque, и внутри самого std:riority_queue видимо какое то некое бинарное дерево работает, но меня интересует, как происходит именно вставка в контейнер.


C++
1
std::priority_queue<int, std::vector<int>, bool(*)(const int&, const int&)> priority_deq_VEC{ compare_func };
Ну вот предположим добавил я 100 элементов, теперь я добавляю 101 элемент, который по своему приоритету должен находится где-то посередине. Как это значение вставится в вектор ? Как обычный .insert() ?

То есть будут перекопированы в новый участок памяти сначала левая часть, потом элемент вставится, потом перекопирована правая часть ?

Или не так ? Просто я проверял на простом тесте заполнение очереди и извлечение самого первого элемента std:riority_queue на основе вектора работает быстрее, чем на основе std::deque - хотя я ожидал обратного эффекта, так как вставка в вектор в любое место кроме конца - это же не эффективная операция.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.10.2023, 18:11
Ответы с готовыми решениями:

C++ priority_queue< int , char*, CompareHeap1 > pqMax (создать очередь с приоритетом для поиска 10 наиболее и наименее часто встречающихся слов)
Выполняю задачу &quot;Частотный словарь&quot;, необходимо создать очередь с приоритетом для поиска 10 наиболее и наименее часто встречающихся слов. ...

Интересное применение очереди с приоритетом (priority_queue)
Здравствуйте, уважаемые пользователи данного форума! Изучая деки, стеки и очереди дошел до такого контейнера как очередь с приоритетом...

Очередь с приоритетом. Элементы с наивысшим приоритетом ставятся в начало очереди, с наименьшим – в конец
Здравствуйте! имеется задание: создать очередь с приоритетом (у каждого элемента свой приоритет). Элементы с наивысшим приоритетом ставятся...

8
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
06.10.2023, 18:26
пирамида

Добавлено через 2 минуты
Цитата Сообщение от Optimus11 Посмотреть сообщение
std:riority_queue на основе вектора работает быстрее, чем на основе std::deque -
с чего бы ей быть медленнее, вектора почти всегда быстрее, потому что лучше всегда иметь непрерывный кусок памяти, чем фрагментарный.
0
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
06.10.2023, 19:12  [ТС]
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
с чего бы ей быть медленнее, вектора почти всегда быстрее, потому что лучше всегда иметь непрерывный кусок памяти, чем фрагментарный.
Я это говорил в рамках вставки элемента. Вставка элемента в середину у вектора самая медленная среди стандартных контейнеров.
Но приоритетная очередь, как то по другому использует вектор - я не могу понять как.
0
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
06.10.2023, 19:58
Optimus11, https://ru.wikipedia.org/wiki/... ра_данных)
1
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
06.10.2023, 20:30  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
Я читал это, но все равно ничего не понял.

Там есть вот такая картинка:
https://upload.wikimedia.org/w... ap.svg.png

Ну предположим я добавляю значение "45", как оно вставится в вектор то ? Прижжётся же всю левую часть без первого элемента переместить на один элемент в право и после этого вставить 45 вторым элементов в приоритете.
0
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
06.10.2023, 21:22
Цитата Сообщение от Optimus11 Посмотреть сообщение
Прижжётся же всю левую часть без первого элемента переместить на один элемент в право
Вставка выполняется в конец, а дальше элементы меняются местами вплоть до восстановления консистентности кучи.
Если сравнивать с обычной пересортировкой массива при каждой вставке, то этих обменов понадобится гораздо меньше (навскидку для случая на картинке примерно в 4 раза).

В стандартной библиотеке есть шаблоны функций std::make_heap, std::push_heap и std::pop_heap. Поэкспериментируйте с ними, чтобы посмотрите наглядно что происходит с элементами.

Добавлено через 11 минут
Optimus11, а еще лучше возьмите книжку Роберта Седжвика, "Фундаментальные алгоритмы на C++ (1-4)", там в параграфе 9.2 все очень понятно объясняется.
1
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
06.10.2023, 22:42  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
Вставка выполняется в конец, а дальше элементы меняются местами вплоть до восстановления консистентности кучи.
Если сравнивать с обычной пересортировкой массива при каждой вставке, то этих обменов понадобится гораздо меньше (навскидку для случая на картинке примерно в 4 раза).

В стандартной библиотеке есть шаблоны функций std::make_heap, std:ush_heap и std:op_heap. Поэкспериментируйте с ними, чтобы посмотрите наглядно что происходит с элементами.

Добавлено через 11 минут
Optimus11, а еще лучше возьмите книжку Роберта Седжвика, "Фундаментальные алгоритмы на C++ (1-4)", там в параграфе 9.2 все очень понятно объясняется.
Но зачем это делается на основе вектора ? Разве вставка и перетасовка не будет быстрее на основе двухсвязного списка ? В очереди с приоритетом же нет произвольного доступа к элементам, только получить элемент с наивысшим приоритетом и удалить его. Разве список не будет тут более подходящим ?
0
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
06.10.2023, 23:08
Цитата Сообщение от Optimus11 Посмотреть сообщение
Разве вставка и перетасовка не будет быстрее на основе двухсвязного списка ?
Не обязательно. Это зависит от характера данных. Логарифмическое время будет и там и там в общем случае. Но массив - гораздо компактее в памяти. Главный недостаток для представления в виде массива - это необходимость заранее знать максимальный размер. Т.е. идеальным для такой очереди была бы ситуация, где размер очереди ограничен каким-то разумным числом сверху. Если такого ограничения нет, то связное представление будет лучше в перспективе роста количества элементов.

Впрочем, возьмите упомянутую книгу и прочитайте. Там есть примеры и тех и других случаев. Не ленитесь. Кроме вас самого знания вам в голову никто не сможет положить.
1
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
08.10.2023, 14:17
Optimus11, а ту что я тебе написал ссылку на вики про кучу ты не читал?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.10.2023, 14:17
Помогаю со студенческими работами здесь

Очередь с приоритетом
Разработать функции работы с приоритетной очередью. Постановка запросов в очередь выполняется по приоритету, снятие - подряд из старших...

Очередь с приоритетом
как реализовать очередь с приоритетом на бинарной куче?при том нужно графически вывести на консоль т.к я поняла графический вывод...

Очередь с приоритетом
У меня есть задание: 9. Разработать шаблон класса для работы с очередью с приоритетами, выполненной в виде односвязного списка. Тип...

Очередь с приоритетом
Всем привет . Собственно нужно организовать очередь с приоритетом. Задание: В офисе один принтер, на печать должны подоватся те...

Очередь с приоритетом
Помогите, пожалуйста, создать из моего класса очередь с приоритетом(приоритетом является money). #include &lt;iostream&gt; #include...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru