Алгоритмы сортировки и понятие анализа алгоритмов. Лекция 1

Содержание

Слайд 2

АНАЛИЗ АЛГОРИТМОВ
Анализ алгоритмов заключается в определении требуемых для его выполнения ресурсов.
Примеры

АНАЛИЗ АЛГОРИТМОВ Анализ алгоритмов заключается в определении требуемых для его выполнения ресурсов.
ресурсов: память, необходимое аппаратное обеспечение, пропускная способность сети, время выполнения.

Слайд 3

ВРЕМЯ РАБОТЫ АЛГОРИТМА
Время работы программы обычно представляется в виде функции от размера

ВРЕМЯ РАБОТЫ АЛГОРИТМА Время работы программы обычно представляется в виде функции от
входных данных.
Время работы алгоритма для некоторых входных данных – это количество элементарных операций или шагов, которые необходимо выполнить.

Слайд 4

СПОСОБЫ ИЗМЕРЕНИЯ РАЗМЕРА ВХОДНЫХ ДАННЫХ
Размер входных данных измеряется по-разному в зависимости

СПОСОБЫ ИЗМЕРЕНИЯ РАЗМЕРА ВХОДНЫХ ДАННЫХ Размер входных данных измеряется по-разному в зависимости
от задачи:
В сортировках массива – это число элементов массива,
В алгоритмах на графах – это может быть несколько чисел (число вершин и число ребер графа),
В перемножении целых чисел – число битов, необходимых для представления входных данных в двоичных обозначениях.

Слайд 5

СОРТИРОВКА ВСТАВКАМИ (1)

Вход алгоритма – массив из n чисел A[1..n]
Insertion_sort(A)
for

СОРТИРОВКА ВСТАВКАМИ (1) Вход алгоритма – массив из n чисел A[1..n] Insertion_sort(A)
j:= 2 to length[A]
do key := A[j]
//вставка элемента A[j] в отсортированную послед-ть A[1..j-1]:
i := j – 1
while i > 0 и A[i] > key
do A[i+1] := A[i]
i := i – 1
A[i+1] := key

Слайд 6

СОРТИРОВКА ВСТАВКАМИ (2)

 

СОРТИРОВКА ВСТАВКАМИ (2)

Слайд 7

СОРТИРОВКА ВСТАВКАМИ (3)

 

СОРТИРОВКА ВСТАВКАМИ (3)

Слайд 8

МЕТОД ДЕКОМПОЗИЦИИ “РАЗБИВАЙ И ВЛАСТВУЙ”

1 этап: Разделение. Сложная задача разбивается на несколько

МЕТОД ДЕКОМПОЗИЦИИ “РАЗБИВАЙ И ВЛАСТВУЙ” 1 этап: Разделение. Сложная задача разбивается на
более простых (которые подобны исходной задаче, но имеют меньший объем).
2 этап. Властвование. Рекурсивное решение вспомогательных задач. Когда объем подзадачи достаточно мал, то она решается непосредственно.
3 этап. Комбинирование. Решение исходной задачи из решений вспомогательных задач.

Слайд 9

СОРТИРОВКА СЛИЯНИЕМ (1)

Разделение: сортируемая последовательность, состоящая из n элементов, разбивается на две

СОРТИРОВКА СЛИЯНИЕМ (1) Разделение: сортируемая последовательность, состоящая из n элементов, разбивается на
меньшие последовательности, каждая из которых содержит n/2 элементов.
Властвование: сортировка обеих вспомогательных последовательностей методом слияния.
Комбинирование: слияние двух отсортированных последовательностей для получения окончательного результата.

Слайд 10

СОРТИРОВКА СЛИЯНИЕМ (2)

Merge_sort(A, p, r) // сортировка элементов в подмассиве A[p, q]
if

СОРТИРОВКА СЛИЯНИЕМ (2) Merge_sort(A, p, r) // сортировка элементов в подмассиве A[p,
(p < r)
then q := [(p+r) / 2]
Merge_sort(A, p, q)
Merge_sort(A, q+1, r)
Merge(A, p, q, r) // слияние двух отсортированных подмассивов

Слайд 11

СОРТИРОВКА СЛИЯНИЕМ (3)

СОРТИРОВКА СЛИЯНИЕМ (3)

Слайд 12

СОРТИРОВКА СЛИЯНИЕМ (4)

Merge_sort (A, p, q, r) //Слияние двух упорядоченных массивов
Создаются два

СОРТИРОВКА СЛИЯНИЕМ (4) Merge_sort (A, p, q, r) //Слияние двух упорядоченных массивов
временных массива L и R, в которые копируются последовательности A[1..q-p+1] и A[r-q, r] соответственно
Указатели текущей позиции ставятся на первые элементы обоих массивов
В итоговом массиве A указатель ставится на позицию j := p.
Пока один из массивов не закончится:
Сравниваются значения текущих элементов, берется меньший из них и копируется в A[j].
В массиве, из которого бы взят элемент, сдвигается указатель текущей позиции
В итоговом массиве указатель сдвигается на следующую позицию: j = j + 1
Все элементы оставшегося массива копируются в A[j..r]
Имя файла: Алгоритмы-сортировки-и-понятие-анализа-алгоритмов.-Лекция-1.pptx
Количество просмотров: 64
Количество скачиваний: 0