Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/25: Рейтинг темы: голосов - 25, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 03.04.2019
Сообщений: 1
1

Сортировка Шелла по Хаббарду

04.04.2019, 00:24. Показов 4511. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, столкнулся с проблемой нерабочего Хаббарда(Хиббарда). Чтобы не крутил в коде - не хочет работать и хоть ты тресни.
Задачей стояло разработать код на сортировку Шелла с шагом Хаббарда (increment=(2^i)-1). Самого Хаббарда брал с форума отсюда же , но что-то пошло не так. Можете ли глянуть? Не могу понять что не так.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <algorithm>
#include <iostream>
#include <stdlib.h>
#include <ctime>
using namespace std;
 
int start, i, j, tmp, N, exch;
 
int ShellSort(int *list, int N) {
    for (i = 1;i < N;i++) {
        int increment = (2 ^ i) - 1;
        if (increment <= N)
        {
            for (start = 0; start < N; start++);
            {
                j = start;
                while(j>=0 && list[j]>list[j+increment]) 
                {
                            tmp = list[j];
                            list[j] = list[j + increment];
                            list[j + increment] = tmp;
                            j=j-1;
                            exch++;
                }
            }
        }
    }
    return  *list, exch;
}
    
 
int main() {
    cout << "Array size: ";
    cin >> N;
    int *list = new int[N];
 
    srand(time(NULL)); //чтобы числа оказались действительными целыми
 
    for (i = 0;i < N;i++)
        list[i] = rand() % 100;
 
    cout << "Random array: ";
    for (i = 0;i < N;i++)
        cout << list[i] << " ";
 
    ShellSort(list, N);
 
    cout << "\n After ShellSort: ";
    for (i = 0;i < N;i++)
        cout << list[i] << " ";
 
    cout << endl << "Number of exchanges: " << exch << endl;
 
    system("pause");
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
04.04.2019, 00:24
Ответы с готовыми решениями:

Сортировка Шелла. Написал программу, не могу понять, почему сортировка не выполняется
Программа создает динамический массив с рандомным заполнением. Дальше выбор сортировок, пузырьком...

Сортировка Шелла и пирамидальная сортировка для символов
Здраствуйте, можете пожалуйста привести пример сортировок шелла и пиромидальной сортировки...

Сортировка Шелла и сортировка вставками
Напишите программу для: 1)Сортировка вставкой 2)сортировка Шелла

Пирамидальная сортировка и сортировка Шелла
Ребята помогите пожалуйста, я NEWBIE и не могу решить такая задача : Выполнить сортировку по...

1
Мозгоправ
1744 / 1038 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
04.04.2019, 02:09 2
Реализация сортировки Шелла взята из Википедии.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
// Сортировка Шелла классическая
template <typename BaseType>
unsigned ShellSort(BaseType *A, unsigned N) {
    unsigned exch = 0;
    unsigned i, j, k;
    BaseType t;
    for (k = N / 2; k > 0; k /= 2)
        for (i = k; i < N; i++) {
            t = A[i];
            for (j = i; j >= k; j -= k) {
                if (t < A[j - k]) {
                    A[j] = A[j - k];
                    ++exch;
                }
                else
                    break;
            }
            A[j] = t;
            ++exch;
        }
    return exch;
}
 
// Сортировка Шелла с шагом Хиббарда
template <typename BaseType>
unsigned ShellSortH(BaseType *A, unsigned N) {
    unsigned exch = 0;
    unsigned i, j, k;
    BaseType t;
    k = 1;
    while ((k << 1 | 1) < N)
        k = (k << 1) | 1;
    for (; k > 0; k >>= 1)
        for (i = k; i < N; i++) {
            t = A[i];
            for (j = i; j >= k; j -= k) {
                if (t < A[j - k]) {
                    A[j] = A[j - k];
                    ++exch;
                }
                else
                    break;
            }
            A[j] = t;
            ++exch;
        }
    return exch;
}
 
int main() {
    int N;
    cout << "Array size: ";
    cin >> N;
    int *list = new int[N];
 
    //srand((unsigned)time(NULL)); //чтобы числа оказались действительными целыми
 
    for (int i = 0; i < N; i++)
        list[i] = rand() % 100;
 
    cout << "Random array: ";
    for (int i = 0; i < N; i++)
        cout << list[i] << " ";
 
    unsigned exch = ShellSortH(list, N);
 
    cout << "\n After ShellSort: ";
    for (int i = 0; i < N; i++)
        cout << list[i] << " ";
 
    cout << endl << "Number of exchanges: " << exch << endl;
 
    //system("pause");
    return 0;
}
0
04.04.2019, 02:09
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
04.04.2019, 02:09
Помогаю со студенческими работами здесь

Сортировка Шелла 2
Не могу понять в чём ошибка компиляции, подскажите пожалуйста) #include &lt;malloc.h&gt; #include...

Сортировка Шелла
Нужно написать программу которая делает сортировку Шелла, сколько кодов уже пересмотрел всё не то!...

Сортировка Шелла
Ребят помогите. есть матрица нужно отсортировать каждую строчку матрицы по убыванию алгоритмом...

Сортировка Шелла
Сортировать массив,массива задаешь сам,но вывод на экран поэтапна или каждый алгоритм должен на...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru