Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 8, средняя оценка - 4.88
gika111
0 / 0 / 0
Регистрация: 04.01.2010
Сообщений: 28
#1

Отсортировать массив методом Шелла - C++

11.01.2010, 23:00. Просмотров 1048. Ответов 1
Метки нет (Все метки)

Здравствуй, помогите пожалуйста решить!
Отсортировать массив, не упорядоченый ни по неубыванию, ни по невозрастанию с помощью сортировки методом Шелла.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.01.2010, 23:00     Отсортировать массив методом Шелла
Посмотрите здесь:

Отсортировать массив методом Шелла C++
Отсортировать массив методом Шелла C++
Отсортировать массив модифицированным методом простого выбора. C++
Отсортировать массив чисел методом пузырька C++
C++ Отсортировать массив с помощью сортировки методом вставки
C++ Отсортировать массив по убыванию методом "пузырька
Нужно отсортировать методом Шелла с++ C++
Отсортировать массив методом выбора C++
C++ Отсортировать массив по убыванию методом пузырька
Отсортировать одномерный динамичный массив методом пузырька C++
C++ Отсортировать одномерный целочисленный массив сортировкой Шелла

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
CyBOSSeR
Эксперт C++
2299 / 1669 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
12.01.2010, 00:01     Отсортировать массив методом Шелла #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
// Функция сортировки Шелла целочисленного массива
// 
// Аргументы:
// arr - сортируемый массив
// size - размер сортируемого массива
void SortShell(int* arr, int size)
{
  assert(arr);
 
  int step = size / 2;
 
  while (step > 0) {
    // Сортируем группы элементов отстоящих друг от друга на значение шага вставками
    for(int i = step; i < size; ++i){
      int tmp = arr[i];
      int j;
 
      for(j = i - step; j>=0 && arr[j] > tmp; j -= step)
        arr[j+step] = arr[j];
 
      arr[j+step] = tmp;
    }    
    step /= 2;
  }
}
Yandex
Объявления
12.01.2010, 00:01     Отсортировать массив методом Шелла
Ответ Создать тему
Опции темы

Текущее время: 12:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru