Сортировка Шелла. Количество сравнений. - C (СИ)

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

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

Здравствуйте! Может кто-нибудь помочь? Требовалось отсортировать массивы разного размера при помощи сортировки Шелла, и оценить количество сравнений и обменов.С количеством обменов я разобрался, а вот как посчитать количество сравнений? Привожу ниже часть кода самой сортировки
Листинг программы
  1. while (step > 0)
  2. {
  3. for (int i = 0; i < (size - step); i++)
  4. {
  5. int j = i;
  6. while (j >= 0 && a[j] > a[j + step])
  7. {
  8. int temp = a[j];
  9. a[j] = a[j + step];
  10. a[j + step] = temp;
  11. j--;
  12. exch+=1;
  13. }
  14. }
  15.  
  16. step =step/2;
  17. }

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

textual
Листинг программы
  1. /* было:
  2. while (j >= 0 && a[j] > a[j + step]) */
  3.  
  4. /* стало: */
  5. while (j >= 0 && greater(a[j], a[j + step]))

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


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

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

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

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы