Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/55: Рейтинг темы: голосов - 55, средняя оценка - 4.65
 Аватар для SunFox25
7 / 6 / 2
Регистрация: 09.08.2018
Сообщений: 27

Сортировка Слиянием vs Быстрая Сортировка - что лучше

13.08.2018, 16:21. Показов 11962. Ответов 6

Студворк — интернет-сервис помощи студентам
Народ, помогите разобраться какой из методов сортировки лучше "Сортировка Слиянием" или "Быстрая Сортировка":
у быстрой худшее время O(n ^ 2), а у сортировки слиянием O(n log n);
среднее время одинаковое - O(n log n);
лучшее - у сортировки слиянием O(n log n), а у быстрой - O(n log n) (обычное разделение) или O(n) (разделение на 3 части);
Затраты пямяти опять же лучше у сортировки слиянием - O(n) вспомогательных, против O(n) вспомогательных + O(log n) вспомогательных у быстрой

Мне почему-то кажеться, что сортировка слиянием лучше, хотя я конечно не разбираюсь в том, что такое это большое "О" и что означает "n log n" (я не понял их перемножить надо (n и логарифм из n) или как?).

Если есть специалист - пожалуйста, разъясните, какой метод всё-таки эффективнее. А то у меня стоит для сортировки текстур сортировка слиянием, а сейчас наткнулся на быструю сортировку, и не знаю, что эффективней.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.08.2018, 16:21
Ответы с готовыми решениями:

3.1 Посмотрите, вроде быстрая сортировка, в любом случае, можете переделать(лучше под с++)?
#include <stdio.h> #include <conio.h> #include <clocale> #include <stdlib.h> #include <math.h> /* выделение памяти */ int...

Сортировка слиянием. В каком куске кода происходит сортировка и каким именно образом?
Помогите, пожалуйста, разобраться. Подскажите в каком куске кода происходит сортировка и каким именно образом? #include <iostream> ...

Что такое быстрая сортировка?
как работает и и для чего она применяется?:(

6
 Аватар для Human_foot
156 / 114 / 36
Регистрация: 27.06.2018
Сообщений: 257
13.08.2018, 16:44
Лучший ответ Сообщение было отмечено SunFox25 как решение

Решение

В гугле первые строки. Вот теория с графиками и таблицами сравнений
https://habr.com/post/188010/
https://ru.wikipedia.org/wiki/... _алгоритма
http://bigocheatsheet.com
1
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
13.08.2018, 16:55
По мне так сортировка слиянием. В прочем если входных данных не много, то как-то и без разницы.

Добавлено через 1 минуту
Цитата Сообщение от SunFox25 Посмотреть сообщение
"n log n" (я не понял их перемножить надо или как?).
Да.
0
 Аватар для SunFox25
7 / 6 / 2
Регистрация: 09.08.2018
Сообщений: 27
13.08.2018, 19:49  [ТС]
Спасибо большое. Оказалось что самая эффективная сортировка - "Поразрядная Сортировка". Но это наверное только для целых чисел, а мне надо для float. Есть ли какой-нибудь способ выполнить поразрядную сортировку для типов float/double?
0
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
13.08.2018, 20:32
Цитата Сообщение от SunFox25 Посмотреть сообщение
Есть ли какой-нибудь способ выполнить поразрядную сортировку для типов float/double?
Если числа положительные, то втупую конвертируешь указатель на массив float в указатель на массив целых беззнаковых чисел того же размера. Отношение порядка при этом сохраняется. Если есть отрицательные числа, то чуть сложнее.
0
 Аватар для SunFox25
7 / 6 / 2
Регистрация: 09.08.2018
Сообщений: 27
14.08.2018, 03:49  [ТС]
Что-то я не уверен, что при таком способе получиться сортировать числа с плавающей запятой, можно пожалуйста доказательства. И как быть с отрицательными числами не могу понять, они очень нужны.
0
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
14.08.2018, 08:15
Цитата Сообщение от SunFox25 Посмотреть сообщение
доказательства
Доказательство напрямую следует из стандарта IEEE-754, который практически везде используется для представления чисел с плавающей точкой. Можешь вручную расписать числа и убедиться.
Цитата Сообщение от SunFox25 Посмотреть сообщение
И как быть с отрицательными числами не могу понять
Если в массиве будут отрицательные числа, то после сортировки он будет почти упорядочен. Необходимо будет немного переставить элементы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.08.2018, 08:15
Помогаю со студенческими работами здесь

Быстрая сортировка. Что не так?
Всем привет. Задание - написать квиксорт с уменьшенной глубиной рекурсии, то есть "сначала сортировать более короткий кусок, а затем...

Подскажите что не в моем коде(Сортировка слиянием)
Я не очень понимаю где именно неверно в моем коде. Хотел рассортировать массив методом слияния. Если найдете заранее спасибо! ...

Быстрая сортировка(сортировка Хоара). Отсортировать фрагмент массива
Мне нужно отсортировать фрагмент массива, расположенный между первым и последним отрицательным элементом. Немогу понять как устоновить...

Быстрая сортировка (сортировка Хоара) для связных списков
есть у кого готовый алгоритм? или подскажите как реализовать

2 сортировки: пирамидальная сортировка и сортировка слиянием
Реализовать два улучшенных алгоритма сортировки. Для каждого алгоритма вычислить показатель качества сортировки (количество операций, т.е....


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru