Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для -Jan-
2 / 2 / 3
Регистрация: 11.05.2013
Сообщений: 65

Правильно ли я посчитал сложность алгоритма Шелла?

27.10.2013, 14:39. Показов 934. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Проверьте пожалуйста, правильно ли я посчитал сложность алгоритма Шелла? Ато с википедией не сходиться.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void shel(ref int[] Mas) // сортировка Шелла
        {
 
            int shag= Mas.Length / 2;
            while (shag> 0) // пока шаг больше 0, делить его на 2   //  "log n"
            {
                for (int i = 0; i < (Mas.Length - shag); i++) // перебор всех значений  //округлил к  "n"
                {
                    
                    if  (Mas[i] > Mas[i + shag]) //   // число сравнений "n * log n"
                    {
                        int buf = Mas[i];           // число перестановок при худшем случае  "n * log n"
                        Mas[i] = Mas[i + shag];
                        Mas[i + shag] = buf;
                    }
                }
                shag= shag/ 2;
            }
             
        }
Значит сложность алгоритма "n * log n" перестановок, и "n * log n" сравнений.
А в википедии пишет : "n * log2 n". Это нужно перестановки и сравнения сложить, чтоли?

Добавлено через 13 минут
Немного ошибся в коде, вместо оператора "if" должен быть следующий код:
C#
1
2
3
4
5
6
7
while ((x >= 0) && (Mas[x] > Mas[x + shag]))
                    {
                        int buf = Mas[x];
                        Mas[x] = Mas[x + shag];
                        Mas[x + krok] = buf;
                        x-=shag;
                    }
Как вычислить сложность оператора "while " ?

Добавлено через 14 минут
Ну, если сложность оператора "while" будет " log n" то все сходится. Только я не уверен что это будет его сложность.

Добавлено через 9 минут
Сделал несколько итераций, оператор "while" исполняется в среднем один раз.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.10.2013, 14:39
Ответы с готовыми решениями:

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

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

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.10.2013, 14:39
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru