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

Быстрая сортировка

19.12.2018, 19:27. Показов 446. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как расширить быструю сортировку для произвольного типа данных?
#include <iostream>
#include <time.h>

using namespace std;

// прототип функции печати
template <typename T>
void printr(T *M, int N);

template <typename T>
void insertion_sort(T *M, int N)
{
T *k;
// пропускаем 1 элемент , указатель не должен выходить за пределвы массива
for (T *i = M + 1; i < M + N; i++)
{
T x = *i;// запоминаем значение вставляемого элемента
for (k = i; k > M && *(k - 1) > x; k--)
{
// "раздвигаем" элементы отсортированной последовательности
*k = *(k - 1);
}
// вставляем х в отсортированную последовательность
*k = x;
}

}

// общие функции
// печать массива
template <typename T>
void printr(T *M, int N)
{
// пока не исчерпались элементы
while (N--> 0)
{
// вывод разыменованного указателя с его(указателя) одновременным сдвигом
cout << *M++ << '\t';
}
cout << '\n';
}
// генерация случайных числовых значений
template <typename T>
T* generator(int size)
{
// резервируем место под массив
T* mas = new T[size];
for (int i = 0;i < size;i++)
{
// заполняем 2 знака до запятой, 2 знака после
mas[i] = rand() % 100 - 50 + (rand() % 100 / 100.0);
}
return mas; // потом массив нужно удалить !
}

// проверка
template <class T>
bool check(T* M, int N)
{
while (--N > 1)
{
if (M[N - 1] > M[N])
// элементы не на месте
return false;
}
// проверили весь массив, нет элементов не на месте
return true;
}


// быстрая сортировка со "сдвигом" массива
void quick_sort(double * M, int N)
{
int i = 0, j = N-1; // первый и последний индексы рассматриваемого подмассива
double c = M[N/2]; // элемент для сравнения
// выполнять, пока индексы не "заскочат" друг за друга
while (i <= j)
{
// элемент слева не на месте
while (i <= j && M[i] < c) i++;
// элемент справа не на месте
while (i <= j && M[j] > c) j--;
if (i <= j)
{
// обмен значениями не на месте
double tmp = M[i];
M[i] = M[j];
M[j] = tmp;
// сдвигаем индексы
i++; j--;
}
}
// здесь же условие завершения рекурсии - элементов <2

if (j>0)
quick_sort(M,j+1);// левая часть
if (i<N-1)
quick_sort(M+i, N-i);// правая часть

}



// более упрощенный вариант сортировки
// массив(не меняется, индекс первого(S) и индекс последнего(F)
// из группы рассматриваемых элементов
void quick_sort(double M[], int S,int F)
{
int i = S, j = F;
double c = M[(S + F) / 2]; // элемент для сравнения выбираем из середины кусочка
// выполнять, пока индексы не "заскочат" друг за друга
while (i <= j)
{
// элемент слева не на месте
while (M[i] < c) i++;
// элемент справа не на месте
while ( M[j] > c) j--;
if (i <= j)
{
// обмен значениями не на месте
double tmp = M[i];
M[i] = M[j];
M[j] = tmp;
// сдвигаем индексы
i++; j--;
}
}
// здесь же условие завершения рекурсии - элементов <2
if(S<j)
quick_sort(M,S, j); // левая часть
if(i<F)
quick_sort(M ,i,F); // правая часть


}



void main()
{
float massiv1[] = { 4,1,0.3,7,6 };
printr(massiv1, 5);
// для засекания времени выполнения
long long start = clock();
long long finish = clock();
#define _20000 200000
srand(time(NULL));
#if 1
cout << "insertion sort\n";
// создаем массив вещественных чисел
double *massiv2 = generator<double>(_20000);
// проверяем, должен получиться несортированный
cout << "Sorted before(0-1) ?" << check(massiv2, _20000) << '\n';
// засекаем время начала сортировки
start = clock();
// сортируем
insertion_sort(massiv2, _20000);
// когда закончилась сортировка
finish = clock();
// проверяем, должен получиться сортированный
cout << "Sorted after(0-1) ?" << check(massiv2, _20000) << '\n';
// printr(massiv2, _20000);
// удаляем массив
delete[] massiv2;
// сколько времени (в компьютерных циклах) заняла сортировка
cout << "delta(insertion)=" << finish - start << '\n';
#endif
// быстрая сортировка маленького массива
double massiv3[] = { 4,1,3,7,6,4};
int col = sizeof(massiv3) / sizeof(massiv3[0]);
cout << "Sorted before(0-1) ?" << check(massiv3, col) << '\n';
quick_sort(massiv3,0,5);
cout << "Sorted after(0-1) ?" << check(massiv3, col) << '\n';
printr(massiv3, col);


cout << "quick sort\n";
// создаем массив вещественных чисел
double *massiv4 = generator<double>(_20000);
// проверяем, должен получиться несортированный
cout << "Sorted before(0-1) ?" << check(massiv4, _20000) << '\n';
// засекаем время начала сортировки
start = clock();
// сортируем
// 2 перегруженные быстрые сортировки
// quick_sort(massiv4, 0, _20000 - 1);
quick_sort(massiv4, _20000);
// когда закончилась сортировка
finish = clock();
// проверяем, должен получиться сортированный
cout << "Sorted after(0-1) ?" << check(massiv4, _20000) << '\n';
// printr(massiv4, _20000);
// удаляем массив
delete[] massiv4;
// сколько времени (в компьютерных циклах) заняла сортировка
cout << "delta(quick)=" << finish - start << '\n';



}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.12.2018, 19:27
Ответы с готовыми решениями:

Быстрая сортировка (сортировка Хоара) для связных списков
есть у кого готовый алгоритм? или подскажите как реализовать

Быстрая сортировка(сортировка Хоара). Отсортировать фрагмент массива
Мне нужно отсортировать фрагмент массива, расположенный между первым и последним отрицательным элементом. Немогу понять как устоновить...

Сортировка Слиянием vs Быстрая Сортировка - что лучше
Народ, помогите разобраться какой из методов сортировки лучше &quot;Сортировка Слиянием&quot; или &quot;Быстрая Сортировка&quot;: у быстрой...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.12.2018, 19:27
Помогаю со студенческими работами здесь

Быстрая сортировка (сортировка методом Хоара)
Ввести массив x1,x2,...,x20 в диапазоне . Требуется расположить отрицательные элементы в порядке убывания. Вывести массивы до и после...

C/C++ FAQ :: Быстрая сортировка (сортировка Хоара)
Вопрос, скорее академический, по мотивам реализации. Вот в faq приведена реализация этого метода сортировки на C++. В коде есть следующий...

Сортировка Хоара / Быстрая сортировка
Доброго времени суток. Написал реализацию алгоритма быстрой сортировки. void SortHhoar(int *arr,int f,int l)//Хоара { int mid = (f...

Сортировка расчёской и быстрая сортировка
В файле in.txt записана последовательность целых чисел. Заданными методами отсортировать числа и записать в файлы out1.txt и out2.txt....

Быстрая сортировка
void qSort(int a, int N) { int i = 0, j = N; int temp, p; p = a; do { while ( a &lt; p ) i++;


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru