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

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

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

Author24 — интернет-сервис помощи студентам
Как расширить быструю сортировку для произвольного типа данных?
#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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.12.2018, 19:27
Ответы с готовыми решениями:

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

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

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

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

0
19.12.2018, 19:27
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.12.2018, 19:27
Помогаю со студенческими работами здесь

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

Сортировка Хоара / Быстрая сортировка
Доброго времени суток. Написал реализацию алгоритма быстрой сортировки. void SortHhoar(int...

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

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

Быстрая сортировка
Дошёл до темы быстрой сортировки, набрал код, начал компилировать. Что-то странно, всё написано...

Быстрая сортировка
Помогите, пожалуйста! Не понимаю почему, но при использовании быстрой сортировки программа выдаёт...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru