Слайд 2Рекурсия
Рекурсия – это прием программирования, при котором функция или программа вызывает сама
себя непосредственно или косвенно.
Например, вычисление факториала легко можно представить рекурсивной функцией
!N = N * !(N-1)
Слайд 3#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] — справа, теперь массив состоит из двух частей, причем элементы левой меньше элементов правой.
Если в подмассиве более двух элементов, рекурсивно запускаем для них ту же функцию.
В конце получится полностью отсортированная последовательность.
Слайд 5void quickSortR(T a[], long N) {
// На входе - массив a[], a[N]
- его последний элемент.
// поставить указатели на исходные места
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 шаг с левой половиной
! Работает только для упорядоченных массивов.
Алгоритм описан для массива отсортированного по возрастанию