Алгоритм. Основные понятия

Содержание

Слайд 2

Понятие

Алгоритм – это формально описанная вычислительная процедура, получающая исходные данные и выдающая

Понятие Алгоритм – это формально описанная вычислительная процедура, получающая исходные данные и
результат вычисления на выход.

Слайд 3

Понятие через отображение

Алгоритм – это некая функция или отображение, которая определяется как

Понятие через отображение Алгоритм – это некая функция или отображение, которая определяется

F: X->Y
X – множество исходных данных
Y – множество значений

Слайд 4

Виды алгоритмов

Механический или жесткий
Вероятностный
Эвристический
Линейный
Ветвящийся
Циклический
Вспомогательный

Виды алгоритмов Механический или жесткий Вероятностный Эвристический Линейный Ветвящийся Циклический Вспомогательный

Слайд 5

Свойства алгоритма

Детерминированность
Понятность
Результативность
Дискретность
Массовость
Конструктивность объектов

Свойства алгоритма Детерминированность Понятность Результативность Дискретность Массовость Конструктивность объектов

Слайд 6

Детерминированность

Предписание, задающее алгоритм должно выполняться однозначно и последовательно для получения конкретного и

Детерминированность Предписание, задающее алгоритм должно выполняться однозначно и последовательно для получения конкретного и однозначного результата
однозначного результата

Слайд 7

Понятность

Все действия должны быть однозначно поняты и выполнены исполнителем, т.е. должны принадлежать

Понятность Все действия должны быть однозначно поняты и выполнены исполнителем, т.е. должны
системе действий данного исполнителя

Слайд 8

Результативность

Указывает на наличие таких исходных данных, для которых реализуемый по заданному алгоритму

Результативность Указывает на наличие таких исходных данных, для которых реализуемый по заданному
вычислительный процесс должен через конечное число шагов остановиться и выдать искомый результат

Слайд 9

Дискретность

Алгоритм представляет собой упорядоченное конечное множество шагов для получения результата, то есть

Дискретность Алгоритм представляет собой упорядоченное конечное множество шагов для получения результата, то
в любом алгоритме для каждого шага (кроме последнего), можно указать следующий за ним шаг.

Слайд 10

Массовость

Каждый алгоритм предназначен для решения любой задачи из некоторого бесконечного множества однотипных

Массовость Каждый алгоритм предназначен для решения любой задачи из некоторого бесконечного множества однотипных задач
задач

Слайд 11

Конструктивность объектов

Исходные объекты, промежуточные и конечные результаты – это конструктивные объекты, которые

Конструктивность объектов Исходные объекты, промежуточные и конечные результаты – это конструктивные объекты,
могут быть построены целиком или допускают кодирование в каких-то алфавитах

Слайд 12

Эффективность алгоритма

Скорость сходимости
Время выполнения
Удобство использования
Простота
Читаемость

Эффективность алгоритма Скорость сходимости Время выполнения Удобство использования Простота Читаемость

Слайд 13

Способы описания алгоритма

Словестное описание
Математическая запись
Графическая запись
Запись на псевдокоде
Запись на ЯП

Способы описания алгоритма Словестное описание Математическая запись Графическая запись Запись на псевдокоде Запись на ЯП

Слайд 14

Правильный алгоритм

Алгоритм считается правильным, если при любом допустимом входе он заканчивает работу

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

Слайд 15

Неправильный алгоритм

Не завершает работу
Дает неверный результат

Неправильный алгоритм Не завершает работу Дает неверный результат

Слайд 16

Типы ошибок в алгоритме

Синтаксические (a+b*(a+c)
Семантические S*N, S – строка, N - число
Логические Расстояние =

Типы ошибок в алгоритме Синтаксические (a+b*(a+c) Семантические S*N, S – строка, N
скорость + время

Слайд 17

Этапы разработки программы

Анализ постановки задач
Построение математической модели
Разработка алгоритма
Анализ алгоритма
Док-во правильности алгоритма
Реализация алгоритма
Тестирование

Этапы разработки программы Анализ постановки задач Построение математической модели Разработка алгоритма Анализ
программы
Оформление документации

Слайд 18

Анализ постановки задач

Выяснить при этом входную и выходную информацию, определить идею решения,

Анализ постановки задач Выяснить при этом входную и выходную информацию, определить идею
полноту входной информации, сформулировать, накладываемые на входную информацию ограничения (то есть описать спецификации)

Слайд 19

Построение математической модели

Определить какие математические структуры больше подходят для задачи, существуют ли

Построение математической модели Определить какие математические структуры больше подходят для задачи, существуют
аналоги решения этой задачи. После чего проверить полноту математической модели, удобство работы с ней, реализации

Слайд 20

Разработка алгоритма

На этом этапе необходимо тщательно обдумать алгоритм, уяснить его достоинства и

Разработка алгоритма На этом этапе необходимо тщательно обдумать алгоритм, уяснить его достоинства
недостатки, постараться избавиться от последних и усилить первые

Слайд 21

Анализ алгоритма

Оценить какой это алгоритм(линейный, с ветвлениями, с циклами). Т.е. оценить его

Анализ алгоритма Оценить какой это алгоритм(линейный, с ветвлениями, с циклами). Т.е. оценить
сложность по памяти и/или быстродействию.

Слайд 22

Док-во правильности алгоритма

Предусматривает как доказательство конечности алгоритма, так и анализ его работы

Док-во правильности алгоритма Предусматривает как доказательство конечности алгоритма, так и анализ его
на всех ветвях на разных типах входных данных

Слайд 23

Реализация алгоритма

Это означает необходимость написания программы на некотором языке программирования и отладка

Реализация алгоритма Это означает необходимость написания программы на некотором языке программирования и
его на реальном компьютере

Слайд 24

Тестирование программы

Т.е. провести ее как теоретическое, так и экспериментальное тестирование. Для алгоритма

Тестирование программы Т.е. провести ее как теоретическое, так и экспериментальное тестирование. Для
необходимо подготовить полный набор тестов (минимальное подмножество входных данных, покрывающее все случаи)

Слайд 25

Оформление документации

Описать технические характеристики, структуру входных и выходных данных, правила использования программы,

Оформление документации Описать технические характеристики, структуру входных и выходных данных, правила использования
при необходимости – реализуемые алгоритмы и возможности модификации.

Слайд 26

Размерность задачи

Размерностью задачи (l) будем называть количество информации достаточного для описания задачи

Размерность задачи Размерностью задачи (l) будем называть количество информации достаточного для описания задачи

Слайд 27

Сложность алгоритма

Временная сложность - T(l) время работы алгоритма
Емкостная сложность – S(l) объем памяти для

Сложность алгоритма Временная сложность - T(l) время работы алгоритма Емкостная сложность –
реализации алгоритма

Слайд 28

Пример

for( i=0; i < n; i++)
for( j = n-1; j >

Пример for( i=0; i for( j = n-1; j > i; j--
i; j-- )
if ( a[j-1] > a[j] )
swap(a[j-1], a[j]);
l = n+1
T(l) = cn2
S(l) = n+3

Слайд 29

Мера сложности алгоритма

Сложность в худшем случае
Усредненная сложность

Мера сложности алгоритма Сложность в худшем случае Усредненная сложность

Слайд 30

Сложность в худшем случае

Зная время работы в худшем случае, мы можем гарантировать,

Сложность в худшем случае Зная время работы в худшем случае, мы можем
что выполнение алгоритма закончится за некоторое время, даже не зная, какой именно вход (данного размера) попадется.
На практике «плохие» входы (для которых время работы близко к максимуму) могут часто попадаться. Например, для базы данных плохим запросом может быть поиск отсутствующего элемента (довольно частая ситуация).
Время работы в среднем может быть довольно близко к времени работы в худшем случае. Пусть, например, мы сортируем случайно расположенные n чисел в помощью процедуры Сортировка вставками.

Слайд 31

Асимптотические обозначения

Анализируя алгоритм, можно стараться найти точное число выполняемых им действий. Но

Асимптотические обозначения Анализируя алгоритм, можно стараться найти точное число выполняемых им действий.
в большинстве случаев достаточно оценить асимптотику роста времени работы алгоритма при стремлении размера входа к бесконечности (asymptotic efficiency)

Слайд 32

f(n) = о(g(n))

 

f(n) = о(g(n))

Слайд 33

f(n) = о(g(n))

2n = o(n2)
log2n = o(n)
n2/2 ≠ o(n2)

f(n) = о(g(n)) 2n = o(n2) log2n = o(n) n2/2 ≠ o(n2)

Слайд 34

f(n) = ω(g(n))

 

f(n) = ω(g(n))

Слайд 35

f(n) = ω(g(n))

2n2 = ω(n)
n = ω(ln n)
n2/2 ≠ ω(n2)

f(n) = ω(g(n)) 2n2 = ω(n) n = ω(ln n) n2/2 ≠ ω(n2)

Слайд 36

f(n) = Θ(g(n))

 

f(n) = Θ(g(n))

Слайд 37

f(n) = Θ(g(n))

n2/2 = Θ(n2)
n2-n+2 = Θ(n2)
Если f(n) = Θ(g(n)) и h(n)

f(n) = Θ(g(n)) n2/2 = Θ(n2) n2-n+2 = Θ(n2) Если f(n) =
= Θ(g(n)), это не значит, что f(n) = h(n)

Слайд 38

f(n) = Θ(g(n))

Отыскивая асимптотически точную оценку для суммы, мы можем отбрасывать члены

f(n) = Θ(g(n)) Отыскивая асимптотически точную оценку для суммы, мы можем отбрасывать
меньшего порядка, которые при больших n становятся малыми по сравнению с основным слагаемым.
Заметим также, что коэффициент при старшем члене роли не играет

Слайд 39

f(n) = O(g(n))

f(n) = O(g(n)), если найдется c>0 и n0, что

f(n) = O(g(n)) f(n) = O(g(n)), если найдется c>0 и n0, что
при всех n≥ n0 выполнено
0≤f(n)≤сg(n)
Говорят, что g(n) есть верхняя оценка f(n).

Слайд 40

f(n) = Ω(g(n))

f(n) = Ω(g(n)), если найдется c>0 и n0, что при

f(n) = Ω(g(n)) f(n) = Ω(g(n)), если найдется c>0 и n0, что
всех n≥ n0 выполнено
0≤cg(n)≤f(n)
Говорят, что g(n) есть нижняя оценка f(n).

Слайд 41

Теорема

f(n) = Θ(g(n))
равносильно условию
f(n) = O(g(n)) и f(n) = Ω(g(n))

Теорема f(n) = Θ(g(n)) равносильно условию f(n) = O(g(n)) и f(n) = Ω(g(n))

Слайд 42

Транзитивность

f(n) = о(g(n)) и g(n) = о(h(n)) => f(n) = о(h(n))
f(n) =

Транзитивность f(n) = о(g(n)) и g(n) = о(h(n)) => f(n) = о(h(n))
ω(g(n)) и g(n) = ω(h(n)) => f(n) = ω(h(n))
f(n) = Θ(g(n)) и g(n) = Θ(h(n)) => f(n) = Θ(h(n))
f(n) = O(g(n)) и g(n) = O(h(n)) => f(n) = O(h(n))
f(n) = Ω(g(n)) и g(n) = Ω(h(n)) => f(n) = Ω(h(n))

Слайд 43

Рефлекcивность

f(n) = Θ(f(n))
f(n) = O(f(n))
f(n) = Ω(f(n))

Рефлекcивность f(n) = Θ(f(n)) f(n) = O(f(n)) f(n) = Ω(f(n))

Слайд 44

Симметричность
f(n) = Θ(g(n)) ⬄ g(n) = Θ(f(n))

Симметричность f(n) = Θ(g(n)) ⬄ g(n) = Θ(f(n))

Слайд 45

Обращение
f(n) = O(g(n)) ⬄ g(n) = Ω(f(n))

Обращение f(n) = O(g(n)) ⬄ g(n) = Ω(f(n))

Слайд 46

Эффективность алгоритмов

Полиномиальные – f(n) = O(nm)
Экспоненциальные - f(n) = O(ap(n))
Факториальные f(n) =

Эффективность алгоритмов Полиномиальные – f(n) = O(nm) Экспоненциальные - f(n) = O(ap(n)) Факториальные f(n) = O(n!)
O(n!)

Слайд 47

Полиномиальные алгоритмы

Постоянный - f(n) = O(1)
Линейный - f(n) = O(n)
Квадратный - f(n)

Полиномиальные алгоритмы Постоянный - f(n) = O(1) Линейный - f(n) = O(n)
= O(n2)
Кубический - f(n) = O(n3)

Слайд 48

Примеры полиномиальных алгоритмов

К линейным алгоритмам относится алгоритм нахождения суммы десятичных чисел, состоящих

Примеры полиномиальных алгоритмов К линейным алгоритмам относится алгоритм нахождения суммы десятичных чисел,
из n1 и n2 цифр. Сложность алгоритма - O(n1 + n2).
Более общий класс полиномиальных алгоритмов –
алгоритмы деления,
извлечения квадратного корня,
решение систем линейных уравнений и др

Слайд 49

Примеры экспоненциальных алгоритмов

Задачи, в которых требуется построить:
множество всех подмножеств данного множества,

Примеры экспоненциальных алгоритмов Задачи, в которых требуется построить: множество всех подмножеств данного

все полные подграфы некоторого графа все поддеревья некоторого графа.

Слайд 50

Другие типы задач

Кратчайшее решение «пятнашек» размера nxn
Задача коммивояжёра
Проблема раскраски графа
Сапер (игра)
Тетрис
составление расписаний,

Другие типы задач Кратчайшее решение «пятнашек» размера nxn Задача коммивояжёра Проблема раскраски
учитывающих определенные условия;
размещение обслуживающих центров (телефон, телевидение, срочные службы) для максимального числа клиентов при минимальном числе центров;
оптимальная загрузка емкости (рюкзак, поезд, корабль, самолёт) при наименьшей стоимости;
оптимальный раскрой (бумага, картон, стальной прокат, отливки), оптимизация маршрутов в воздушном пространстве, инвестиций, станочного парка;
задача распознавания простого числа

Слайд 51

Числа Фибоначчи

0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55….
F0=0, F1=1,

Числа Фибоначчи 0, 1, 1, 2, 3, 5, 8, 13, 21, 34,
Fn=Fn-1+Fn-2, n>1
Рекурсивный алгоритм
Нерекурсивный алгоритм

Слайд 52

Рекурсивный алгоритм

int Fibonacci(int n){
if(n==0)
return 0;
if(n==1)
return 1;
return Fibonacci(n-1)+Fibonacci(n-2);
}

Рекурсивный алгоритм int Fibonacci(int n){ if(n==0) return 0; if(n==1) return 1; return Fibonacci(n-1)+Fibonacci(n-2); }

Слайд 53

Нерекурсивный алгоритм

int Fibonacci(int n){
if(n==0)
return 0;
int prev = 0;
int current = 1;
for(int i=2;i<=n;++i)
{
int

Нерекурсивный алгоритм int Fibonacci(int n){ if(n==0) return 0; int prev = 0;
temp = current;
current += prev;
prev = temp;
}
return current;
}
Имя файла: Алгоритм.-Основные-понятия.pptx
Количество просмотров: 39
Количество скачиваний: 0