|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
||||||
САМАЯ БЫСТРАЯ сортировка!22.01.2010, 00:29. Показов 29008. Ответов 59
Метки нет (Все метки)
Теоретически и практически доказано, что сортировка OVERPOWER8 - самая быстрая в мире.
Характеристика: Требуется памяти: 3*N Количество шагов в любом случае: 3*N Стабильная: ДА Метод: Замена Если не верите, то можете проверить:
Не знаю, почему codepad.org выдает Segmentation Fault, у меня на Linux G++ все работает замечательно.
1
|
||||||
| 22.01.2010, 00:29 | |
|
Ответы с готовыми решениями:
59
Самая быстрая сортировка Какая библиотека самая быстрая для вычисления md5 и sha1? Быстрая сортировка(сортировка Хоара). Отсортировать фрагмент массива |
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
||||||
| 22.01.2010, 02:51 [ТС] | ||||||
|
>> CyBOSSeR
Понятно. А в случае с vector <int> array( 20 000 000); проблем не будет? Если нет, то как передать вектор в функцию?
Только бы узнать как
0
|
||||||
|
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
|
||||||||||||
| 22.01.2010, 02:58 | ||||||||||||
1
|
||||||||||||
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 03:04 [ТС] | |
|
>> CyBOSSeR
Хорошо. Спасибо за ответы. А как вы относитесь к тому, как я этим же методом буду сортировать массив, содержащий и отрицательные элементы (ранее распиал) ?
0
|
|
|
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
|
||
| 22.01.2010, 03:11 | ||
|
Насчет работы с отрицательными элементами - овчинка выделки не стоит. Доработка этого алгоритма для отрицательных чисел повлечет дополнительные накладные расходы, а, соответственно, скорость будет падать. Да и вообще я бы не советовал дальше пытать этот алгоритм - толку от него не будет (ни в скорости, ни в памяти). Хотя отрицательный опыт не менее ценен (а то и более), чем положительный. Так что пробуй, пытайся, хотя бы для опыта.
0
|
||
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 22.01.2010, 06:47 | |
|
OVERPOWER8, где здесь 3*N? Я вижу N*m, где m может здорово плавать и значительно превышать N. То есть ты по-моему первый, кому удалось сделать сортировку хуже пузырька.
1
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 12:09 [ТС] | |
|
>> taras atavin
Ни хрена себе! Проверьте конкретно мой пример.
0
|
|
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
| 22.01.2010, 12:11 | |
|
У тебя цикл по элементам, а в нем ещё по значениям. Ну и как ты предлагаешь получить 3*N?
0
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 12:13 [ТС] | |
|
>> CyBOSSeR
Вот с вами НЕ соглашусь! Как я уже писал, в определенных случаях этот алгоритм будет самым быстрым! И с этим нельзя не согласиться. Просто в программе сделаю три вещи: 1. Пирамидальная сортировка (O(n)*long(n)) 2. Сортировка OVERPOWER8 (O*m), m=3, 4, 5, ... В зависимости от случая. 3. Анализ последовательности, чтобы выбрать правильную сортировку. И вижу все причины для доработки моего алгоритма. Пол года поработаю над моей сортировкой, и она будет лучше, чем быстрая и пирамидальная вместе взятые.
0
|
|
|
|
|
| 22.01.2010, 14:26 | |
|
Подозреваю, что в коде нечисто то, что Sort выделается динамически, но при этом его элементы остаются неинициализированными. В итоге строки 25 и 26 ведут себя недетерминировано
А вообще, этот метод и твои комментарии к нему мне очень напоминают институтские уроки химии. Там был закон имени какого-то мужика, в котором утверждалось, что для всех элементов периодической системы кроме (дальше перечисляется чуть ли не полтаблицы, причём никакой системы в этом нет) в диапазоне температур ПРИМЕРНО от 20 до 70 градусов цельсия при давлении ПРИМРНО в одну атмосферу и влажности ПРИМЕРНО такой-то что-то там выполнялось. Это они называли словом ЗАКОН. Вот и сортировка у тебя такая же - работает только в каких-то узкоопределённых условиях, которые в реальной жизни практически не нужны. Ну это так, чисто к сведению
1
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|||||||
| 22.01.2010, 14:47 [ТС] | |||||||
|
И результат подели на количество элементов. как-то так:
0
|
|||||||
|
depict1
281 / 146 / 4
Регистрация: 11.07.2009
Сообщений: 606
|
||
| 22.01.2010, 14:58 | ||
|
>Ну и как ты предлагаешь получить 3*N?
0
|
||
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
||||||
| 22.01.2010, 15:00 [ТС] | ||||||
|
>> zim22
А что не нравится?
И предусмотреть другую сортировку, а также проверку, когда какой сортировкой пользоваться. Я забыл упомянуть, что эта сортировка в процессе разработки.
0
|
||||||
|
1261 / 799 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
|
|
| 22.01.2010, 15:14 | |
|
OVERPOWER8:
Если человек изобрёл алгоритм, зачем его дарить другим людям. Вероятно этот алгоритм не особо ценен. Добавлено через 21 секунду Запатентуй изобретение. Добавлено через 2 минуты Я бы если бы, изобрел какой-то "суперский алгоритм" на форум точно бы его не выложил.
0
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 15:16 [ТС] | |
|
>> Genius Ignat
А мне не жалко, пусть другие тоже пользуются. Может кто и поможет его доработать. Только надо добавить функцию-анализ, которая решает, имеет ли смысл пользоваться этим алгоритмом или выбрать другой. В противном случае последовательность сортируется другим способом, например, qsort.
0
|
|
|
1261 / 799 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
|
|
| 22.01.2010, 15:18 | |
|
OVERPOWER8:
функцию-анализ. Если анализировать последовательность, значит тратить время.
0
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 15:19 [ТС] | |
|
>> Genius Ignat
У меня есть также суперский алгоритм Шифра Вернама. Но он не всегда идеален, и тоже в процессе разработки. Думаю, знаешь, что такое Шифр Вернама.
0
|
|
|
1261 / 799 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
|
|
| 22.01.2010, 15:21 | |
|
OVERPOWER8:
Надеюсь анализ не будет дольше сортировки. Добавлено через 1 минуту OVERPOWER8: Может тебе дать ссылочку на достижение человечества: лучшие алгоритмы.
0
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
||
| 22.01.2010, 15:21 [ТС] | ||
|
>> Genius Ignat
0
|
||
|
1261 / 799 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
|
|
| 22.01.2010, 15:24 | |
|
OVERPOWER8:
А кстати видел один сайт на котором описывалась производительность алгоритмов сортировки, не просто описывалась, там производились тесты с последовательностями различных размеров.
0
|
|
|
19 / 19 / 2
Регистрация: 29.11.2009
Сообщений: 224
|
|
| 22.01.2010, 15:26 [ТС] | |
|
>> Genius Ignat
Я таких книг несколько прочитал.
0
|
|
| 22.01.2010, 15:26 | |
|
Помогаю со студенческими работами здесь
40
Быстрая сортировка (сортировка Хоара) для связных списков
Сортировка Хоара / Быстрая сортировка Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|