- •Объектно-ориентированное программирование Курсовой проект «Сортировка и поиск в массивах»
- •Введение
- •1.Алгоритмы сортировки
- •1.1.Сортировка методом пузырька
- •1.2.Сортировка методом Выбора (метод локального минимума)
- •1.3.Сортировка методом Вставки
- •1.4.Сортировка Быстрым методом
- •2.Алгоритмы поиска
- •2.1.Прямой поиск
- •2.2.Бинарный поиск
- •2.3.Интерполяционный поиск
- •3.Реализация оценки эффективности алгоритмов в программе
- •3.1.Исходные данные
- •3.2.Способы оценки эффективности
- •3.3.Реализация подсчета кол-ва сравнений, присваиваний и эффективности в программе
- •3.4.Реализация замера времени выполнения алгоритмов сортировки в программе
- •3.5.Реализация представления результата в программе
- •4.Результат определения эффективности алгоритмов
- •5.Структура прграммы
- •5.1.Интерфейс программы
- •5.2.Описание структуры программы
- •5.2.1.Глобальная структура для хранения статистики
- •5.2.2.Основной модуль Unit1.Cpp (для Формы Form1)
- •5.2.3.Модуль Unit2.Cpp (для Формы GrafForm)
- •6.4.Файл Unit2.Cpp
- •Заключение
- •Список используемой литературы
1.4.Сортировка Быстрым методом
Быстрая сортировка является одним из самых эффективных и распространенных методов. Суть метода заключается в разделении массива на две части от опорного элемента. Все меньшие или равные опорному в левую часть, а все большие или равные опорному в правую. Затем рекурсивно запускаем ту же операцию для каждой части и так до конца сортировки.
Рассмотрим алгоритм более подробно.
Введем два указателя: i и j. В начале алгоритма они указывают, соответственно, на левый и правый конец последовательности.
Будем двигать указатель i с шагом в 1 элемент по направлению к концу массива, пока не будет найден элемент a[i] >= p. Затем аналогичным образом начнем двигать указатель j от конца массива к началу, пока не будет найден a[j] <= p.
Далее, если i <= j, меняем a[i] и a[j] местами и продолжаем двигать i,j по тем же правилам...
Повторяем шаг 3, пока i <= j.
Рекурсивно вызываем эту же функцию для каждой части.
Блок-схема и алгоритм метода представлен ниже:
Рис. 1.4. Блок-схема Быстрой сортировки
void quickSortR(long* array, long N) {
// На входе - массив array[], a[N] - его последний элемент.
long i = 0, j = N; // поставить указатели на исходные места
long temp, p;
p = array[N>>1]; // центральный элемент
// процедура разделения
do {
while ( array[i] < p ) i++;
while ( array[j] > p ) j--;
if (i <= j) {
temp = array[i];
array[i] = a[j];
array[j] = temp;
i++;
j--;
}
} while ( i<=j );
// рекурсивные вызовы, если есть, что сортировать
if ( j > 0 ) quickSortR(array, j);
if ( N > i ) quickSortR(array+i, N-i);
}
Каждое разделение требует, очевидно, Theta(n) операций. Количество шагов деления(глубина рекурсии) составляет приблизительно log n, если массив делится на более-менее равные части. Таким образом, общее быстродействие: O(n log n), что и имеет место на практике.
Однако, возможен случай таких входных данных, на которых алгоритм будет работать за O(n2) операций. Такое происходит, если каждый раз в качестве центрального элемента выбирается максимум или минимум входной последовательности. Если данные взяты случайно, вероятность этого равна 2/n. И эта вероятность должна реализовываться на каждом шаге... Вообще говоря, малореальная ситуация.
Метод неустойчив. Поведение довольно естественно, если учесть, что при частичной упорядоченности повышаются шансы разделения массива на более равные части.
Сортировка использует дополнительную память, так как приблизительная глубина рекурсии составляет O(log n), а данные о рекурсивных подвызовах каждый раз добавляются в стек.
2.Алгоритмы поиска
В данной главе будут описаны три алгоритма поиска, которые были использованы в курсовом проекте – прямой, бинарный и интерполяционный.
2.1.Прямой поиск
Этот метод поиска является элементарным и основан на прямом переборе массива с условием проверки равенства элементов массива и искомого значения, отсюда и название – прямой поиск.
Реализация его может выглядеть, например так:
long DirectFind(long array[], long size, long What)
{
long i, Found;
Found=-1;
for (i=0; i<size; i++)
if (array[i] == What) {
Found == i;
break;
}
return Found;
}