|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||||||
std::priority_queue - очередь с приоритетом06.10.2023, 18:11. Показов 686. Ответов 8
Метки нет (Все метки)
Здравствуйте,
Подскажите пожалуйста, как работает std: riority_queue внутри ?То есть я понимаю, что это некий адаптер к std::vector и std::deque, и внутри самого std: riority_queue видимо какое то некое бинарное дерево работает, но меня интересует, как происходит именно вставка в контейнер.
То есть будут перекопированы в новый участок памяти сначала левая часть, потом элемент вставится, потом перекопирована правая часть ? Или не так ? Просто я проверял на простом тесте заполнение очереди и извлечение самого первого элемента std: riority_queue на основе вектора работает быстрее, чем на основе std::deque - хотя я ожидал обратного эффекта, так как вставка в вектор в любое место кроме конца - это же не эффективная операция.
0
|
||||||
| 06.10.2023, 18:11 | |
|
Ответы с готовыми решениями:
8
C++ priority_queue< int , char*, CompareHeap1 > pqMax (создать очередь с приоритетом для поиска 10 наиболее и наименее часто встречающихся слов) Интересное применение очереди с приоритетом (priority_queue) Очередь с приоритетом. Элементы с наивысшим приоритетом ставятся в начало очереди, с наименьшим – в конец |
|
|
||
| 06.10.2023, 18:26 | ||
|
пирамида
Добавлено через 2 минуты
0
|
||
|
-41 / 49 / 5
Регистрация: 10.01.2017
Сообщений: 1,915
|
||
| 06.10.2023, 19:12 [ТС] | ||
|
Но приоритетная очередь, как то по другому использует вектор - я не могу понять как.
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 [ТС] | ||
|
Там есть вот такая картинка: https://upload.wikimedia.org/w... ap.svg.png Ну предположим я добавляю значение "45", как оно вставится в вектор то ? Прижжётся же всю левую часть без первого элемента переместить на один элемент в право и после этого вставить 45 вторым элементов в приоритете.
0
|
||
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
||
| 06.10.2023, 21:22 | ||
|
Если сравнивать с обычной пересортировкой массива при каждой вставке, то этих обменов понадобится гораздо меньше (навскидку для случая на картинке примерно в 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 [ТС] | ||
|
0
|
||
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
||
| 06.10.2023, 23:08 | ||
|
Впрочем, возьмите упомянутую книгу и прочитайте. Там есть примеры и тех и других случаев. Не ленитесь. Кроме вас самого знания вам в голову никто не сможет положить.
1
|
||
|
|
|
| 08.10.2023, 14:17 | |
|
Optimus11, а ту что я тебе написал ссылку на вики про кучу ты не читал?
0
|
|
| 08.10.2023, 14:17 | |
|
Помогаю со студенческими работами здесь
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 .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|