Программирование на языке С Урок 11. Рекурсия, быстрая сортировка

Слайд 2

Рекурсия

Рекурсия – это прием программирования, при котором функция или программа вызывает сама

Рекурсия Рекурсия – это прием программирования, при котором функция или программа вызывает
себя непосредственно или косвенно.
Например, вычисление факториала легко можно представить рекурсивной функцией
!N = N * !(N-1)

Слайд 3

#include
using namespace std;
long int Fact(long int N)
{
// если произведена попытка вычислить

#include using namespace std; long int Fact(long int N) { // если
факториал нуля
if (N < 1) return 0;
// если вычисляется факториал единицы
// именно здесь производится выход из рекурсии
else if (N == 1) return 1;
// любое другое число вызывает функцию заново с формулой N-1
else return N * Fact(N-1);
}
void main()
{
long number = 5;
// первый вызов рекурсивной функции
long result = Fact(number);
cout << "Result " << number << "! is - " << result << "\n";
}

Слайд 4

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

Из массива выбирается некоторый опорный элемент a[i].
Запускается функция разделения массива, которая

Быстрая сортировка Из массива выбирается некоторый опорный элемент a[i]. Запускается функция разделения
перемещает все ключи, меньшие, либо равные a[i], слева от него, а все ключи, большие, либо равные a[i] — справа, теперь массив состоит из двух частей, причем элементы левой меньше элементов правой.
Если в подмассиве более двух элементов, рекурсивно запускаем для них ту же функцию.
В конце получится полностью отсортированная последовательность.

Слайд 5

void quickSortR(T a[], long N) {
// На входе - массив a[], a[N]

void quickSortR(T a[], long N) { // На входе - массив a[],
- его последний элемент.
// поставить указатели на исходные места
long i = 0, j = N;
T temp, p;
p = a[ N/2 ]; // центральный элемент
// процедура разделения
do {
while ( a[i] < p ) i++;
while ( a[j] > p ) j--;
if (i <= j) {
temp = a[i];
a[i] = a[j];
a[j] = temp;
i++;
j--;
}
} while ( i <= j );
// рекурсивные вызовы, если есть, что сортировать
if ( j > 0 ) quickSortR(a, j);
if ( N > i ) quickSortR(a+i, N-i);
}

Слайд 6

Двоичный поиск

Ищем срединный элемент и сравниваем с искомым значением
Если значения равны, поиск

Двоичный поиск Ищем срединный элемент и сравниваем с искомым значением Если значения
завершаем
Если искомое больше срединного элемента, то повторяете 1 шаг с правой половиной массива
Если искомое меньше срединного элемента, то повторяете 1 шаг с левой половиной
! Работает только для упорядоченных массивов.
Алгоритм описан для массива отсортированного по возрастанию
Имя файла: Программирование-на-языке-С-Урок-11.-Рекурсия,-быстрая-сортировка.pptx
Количество просмотров: 193
Количество скачиваний: 0