Функция сортировки Шелла

Сортировка включениями с убывающим приращением

В 1959 г. Д. Шеллом было предложено усовершенствование сортировки с помощью прямого включения. Сам метод сортировки объясняется и демонстрируется на стандартном примере (рис. 3.5). Сначала отдельно группируются и сортируются элементы, отстоящие друг от друга на 4 позиции. Такой процесс называется четвертной сортировкой. В нашем примере восемь элементов каждая группа состоит ровно из двух элементов. После первого прохода элементы перегруппировываются — теперь каждый элемент группы отстоит от другого на две позиции — и вновь сортируются. Это называется двойной сортировкой. Наконец, на третьем проходе идет обычная сортировка [1,3,9,10,13].

Сначала может показаться, что необходимость нескольких проходов сортировки, в каждом из которых участвуют все элементы, потребует большего количества машинных ресурсов, чем обычная сортировка. Однако на каждом этапе либо сортируется относительно мало элементов, либо элементы уже довольно хорошо упорядочены и требуется сравнительно немного перестановок.

Ясно, что такой метод в результате дает упорядоченный массив, и, конечно же, сразу видно, что каждый проход от предыдущих только выигрывает (так как каждая /-сортировка объединяет две группы, уже отсортированные 2i-сортировкой). Очевидно так же, что расстояния в группах можно уменьшать по-разному, лишь бы последнее было единичным, ведь в самом плохом случае последний проход и сделает всю работу.

 

 

void shellSort(int numbers[], { int i, j, increment, temp; int array size)
 
increment = 3;  
while (increment > 0) {  

for (i=0; i < array_size; i++)

{

j = i;

temp = numbers[i];

while( (j >=increment)&&(numbers[j-increment]>temp]

{

numbers[j] = numbers[j - increment]; j = j - increment;


}

numbers[j


temp;


}

if (increment/2 != 0)

increment = increment/2; else if (increment == 1)

increment = 0; else

increment = 1;

| 44 | 55 | 12 | 42 | 94 | 18 || 06 ||"67