Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
698 / 572 / 75
Регистрация: 20.09.2014
Сообщений: 3,699

Сложность алгоритма ENTHROPY_SORT

11.09.2015, 20:18. Показов 454. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Господа, прошу протестировать следующий алгоритм сортировки в реальных условиях и сравнить с:
1. быстрой сортировкой,
2. пирамидальной сортировкой и
3. сортировкой слиянием.
применив
1. массив со случайными числами
2. монотонно возрастающий массив
3. монотонно убывающий массив
4. массив вида X[i]:=i*(n-i)
4. массив вида X[i]:=100*sin(10*pi*i/n)

Обратите внимание, сортируемый массив A размера n. Число n должно быть степенью двойки (32, 64, 128, 256, 512 и т.д.), иначе алгоритм не сильно хорошо работает.

Обратите внимание, что размер
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
ENSORT(A)
    for i=0 to n-1
        T[i]:=1
    for i=1 to log2(n)
        for j=0 to n/2^i-1
            if A[j*2^i] > A[j*2^i+2^(i-1)]
                SWAP_BLOCKS(j*2^i, 2^(i-1), 2^(i-1))
            T[j*2^i]:=T[j*2^i]+T[j*2^i+2^(i-1)]
    for i=1 to n-1
        while (i+T[i]<n)
            if A[i] > A[i+T[i]]
                SWAP_BLOCKS(i, T[i], T[i + T[i]])
            T[i]:=T[i]+T[i + T[i]]
Code
1
2
3
4
5
6
7
8
9
SWAP_BLOCKS(start,n1,n2)
    for j=0 to n2-1
        swap[start+j]:=A[start+n1+j]
        swapt[start+j]:=T[start+n1+j]
    for j=0 to n1-1
        swap[start+n2+j]:=A[start+j]
        swapt[start+n2+j]:=T[start+j]
    A:=swap
    T:=swapt
Принимаются любые предложения по оптимизации. Очевидно, в первую очередь нужно заоптимизировать SWAP_BLOCKS. Также неплохо было бы оценить теоретическую сложность алгоритма.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.09.2015, 20:18
Ответы с готовыми решениями:

Сложность Алгоритма
Помогите пожалуйста разобраться. Я не прошу за меня решать!!!! В данной задаче нужно заполнить таблицу.Пара вопросов: 1)Я не совсем...

Сложность алгоритма
пусть имеется алгоритм f со сложностью О(n*log n). Если этот алгоритм запускается в цикле n раз for(int i=0;i&lt;n;i++) { ...

Сложность Алгоритма
народ подскажите пожалуйста как посчитать сложность вот такого кода (или хотя бы литературу подкинте) while i&lt;=length(s) do ...

1
698 / 572 / 75
Регистрация: 20.09.2014
Сообщений: 3,699
17.09.2015, 04:35  [ТС]
Спасибо, ребята, за внимание. Уже не нужно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.09.2015, 04:35
Помогаю со студенческими работами здесь

Сложность алгоритма
Кто бы объяснил рабоче-крестьянским языком что такое O(N) ? И если есть сложность алгоритма O(N + M) и я хочу разбить на 2 подзадачи, то...

сложность алгоритма
подскажите, как росчитать сложность алгоритма. в том числе алгоритм сортиро́вки пузырько́м : procedure sort_bulbaska(var A:mas); ...

Сложность алгоритма
Нужно определить сложность алгоритма. Я совсем не понял как это делается. Program Spline; uses crt,dos; type vector=array of...

Сложность алгоритма
Есть псевдокод следующего алгоритма function search(k,m: int, x:double): bool; var l: int; p,q: bool begin if k = m...

Сложность алгоритма
Здравствуйте. Подскажите, как можно определить сложность многократной рекурсии. Вот нашел информацию, но фраза но фраза ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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