Сортировка Шелла - C (СИ) (156445)

Узнай цену своей работы

Формулировка задачи:

Помогите разобраться. Пока что только это - целочисленная сортировка:
int array[size] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1}, temp = 0, step = 0, a = 0, b = 0;
 
for (a = 2; a <= size; a+=2)
{
    step = size / 2;
 
    for(int b = 0; b < size-step; b++)
    {
        if(array[b] > array[b + step])
        {
            temp = array[b];
            array[b] = array[b + step];
            array[b + step] = temp;
        }
    }
    step /= 2;
}

Решение задачи: «Сортировка Шелла»

textual
Листинг программы
step = size / 2;
 
while(step > 0)
{
    for(a = 1; a < size; a++)
    {
        if(array[b] > array[b + step])
        {
            temp = array[b];
            array[b] = array[b + step];
            array[b + step] = temp;
            b = b - size;
        }
        else
        {
            b = -1;
        }
    }
step = step / 2;
}

Объяснение кода листинга программы

  1. Начинается с инициализации переменной step, которая равна size / 2, где size - это размер массива.
  2. Затем, в цикле while, который выполняется до тех пор, пока step больше 0, происходит сортировка массива.
  3. Внутри цикла while находится вложенный цикл for, который проходит по всем элементам массива, начиная с индекса 1 и до size - 1.
  4. Внутри вложенного цикла for проверяется, является ли элемент array[b] больше элемента array[b + step]. Если это так, то выполняется следующий код:
  5. Переменная temp инициализируется значением array[b].
  6. Значение array[b] заменяется значением array[b + step].
  7. Значение array[b + step] заменяется значением temp.
  8. Значение b обновляется на b - size, чтобы начать следующую итерацию внешнего цикла с начала.
  9. Если элемент array[b] не больше элемента array[b + step], то переменная b обновляется на -1, что означает, что массив уже отсортирован.
  10. После окончания вложенного цикла for, значение step обновляется на step / 2.
  11. Цикл while повторяется до тех пор, пока step больше 0, что означает, что массив продолжает сортироваться, пока не будет полностью отсортирован.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

15   голосов , оценка 4.067 из 5