Мы поможем в написании ваших работ!



ЗНАЕТЕ ЛИ ВЫ?

Сравнительный Анализ очередей с приоритетом

Поиск

Сравнение рассмотренных выше куч приведено в таблице

  Бинарная куча Биномиальная куча Фибоначчиева куча 2-3 куча
Вставка Θ (log n) O(log n) Θ (1) Θ (1)
Извлечение приоритетного Θ (log n) Θ (log n) O(log n) O (log n)
Поиск приоритетного O(1) O (1) Θ (1) Θ (1)
Изменение ключа Θ (log n) Θ (log n) Θ (1) Θ (1)
Слияние Θ (n) Ω (log n) Θ (1) Θ (1)
Достоинства 1) Простота реализации 2) Требуют меньше всего памяти 1) Все операции кроме поиска выполняются за логарифмическое время 1) Все операции кроме тех, что требуют удаления выполняются за константное время 1) Все операции кроме тех, что требуют удаления выполняются за константное время
Недостатки 1) Слияние за линейное время 2) Не оптимальное быстродействие 1) Не оптимальное быстродействие 2) Не оптимальный расход памяти 1) Скорость работы зависит от порядка следования операций 2) Не оптимальный расход памяти 1) Очень сложны в реализации 2) Не оптимальный расход памяти

Таблица 3: Сравнительный анализ рассмотренных куч

В алгоритмах на графах операция слияния как правило не используется, значит биномиальную кучу из дальнейшего сравнения можно исключить. Куча Фибоначчи и 2-3 куча становятся основными соперниками в дальнейшем сравнениями. Бинарная куча также будет присутствовать в сравнении чтобы можно было оценить необходимость использования более тяжелых структур данных.

 

 

Анализ производился на машине со следующими характеристиками:

ОС: Windows 7 Максимальная SP1

Процессор: Intel Pentium CPU 2030M 2x2.50GHz

Тип системы: 32-разрядная

Среда разработки и тестирования: Visual Studio Ultimate 2013.

В качестве бинарной кучи будем использовать std::priority_queue из библиотеки шаблонов C++. Фибоначчиева куча и 2-3 куча были реализованы мной.

Важной характеристикой является расход памяти, поэтому сделаем сравнение расходуемой памяти при различных размерах куч

 

Рисунок 4.1: Анализ занимаемой памяти.

 

Видно, что Бинарная куча занимает на порядок меньше памяти чем другие кучи. Хуже всего показала себя Фибоначчиева куча (приблизительно на 10% хуже, чем 2-3 куча).

 

Далее сравним предельные случаи операций вставки-удаления, поскольку это наиболее используемые операции.

Рисунок 4.2 - Зависимость времени выполнения вставки-удаления от количества вершин (вставка N вершин,затем удаление)

 

Рисунок 4.3 - Зависимость времени выполнения вставки-удаления от количества вершин (N раз вставка-удаление по одной вершине)

 

Видно, что при 2000 в первом случае 2-3 куча отработала в 2 раза медленнее чем во втором. Куча Фибоначчи отработала в 9 раз медленнее. Бинарная куча отработала на порядок хуже. По данному тесту 2-3 куча показала наилучший показатель быстродействия. Следовательно, 2-3 куча меньше всего зависит от режима поступления операций.

 



Поделиться:


Последнее изменение этой страницы: 2017-02-06; просмотров: 173; Нарушение авторского права страницы; Мы поможем в написании вашей работы!

infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 13.58.84.207 (0.008 с.)