Similar presentations:
Лекция_05_Алгоритмы
1.
12.
ДискретностьДетерминированность
Конечность
(финитность)
Результативность
Элементарность
Понятность
Массовость
Завершаемость
2
3.
34.
Псевдокод - это система обозначений, предназначенная для неформального представления идей в процессеразработки алгоритмов.
name = выражение
• Если валовой внутренний продукт растет, покупать обыкновенные акции; в противном случае продавать
обыкновенные акции.
• Покупать обыкновенные акции, если валовой внутренний продукт растет, и продавать их в противном случае.
i f (условие) :
дей̆ствие
else:
действие
В зависимости от того, является год високосным или нет, разделить итог на 366 или 365 соответственно.
i f (год високосный):
ИтогоЗаДень = Итог / 366
else:
ИтогоЗаДень = Итог / 365
4
5.
Мы также примем сокращенный̆ синтаксис этого конструкта:if (условие):
действие
Итерация - это повторение некоторой части алгоритма до тех пор, пока не будет выполнено заданное условие либо
пока она не будет выполнена указанное количество раз.
Универсальный шаблон:
while (условие):
действие
while (имеются билеты, которые можно продать):
продавать билеты
Упорядоченные (последовательно выполняемые) инструкции, выбор и итерация являются строительными
блоками алгоритмов.
Любой̆ алгоритм может быть реализован с использованием только упорядоченных инструкций, выбора и
итерации.
def имя( ):
If (. . .):
ПредоставлениеЗайма( )
else:
ОтклонениеЗаявки( )
def Сортировка (Список):
5
6.
Фаза 1. Понять существо задачи.Фаза 2. Разработать план решения задачи.
Фаза 3. Выполнить план.
Фаза 4. Оценить точность решения, а также
его потенциал в качестве средства для
решения других задач.
Фаза 1. Понять существо задачи.
Фаза 2. Предложить идею, какая
именно алгоритмическая процедура
позволила
бы
решить
задачу.
Фаза 3. Сформулировать алгоритм и
представить его в виде программы.
Фаза 4. Оценить точность программы и
ее потенциал в качестве средства для
решения других задач.
6
7.
Задача. Предположим, что некто А хочет определить возраст трех детей некоего В. Этот В сообщает А, чтопроизведение возрастов его детей̆ равно 36. Обдумав эту подсказку, А отвечает, что необходима еще
подсказка, и В сообщает ему сумму возрастов его детей̆. Затем А отвечает, что требуется еще подсказка, и
В говорит ему, что старший из детей̆ играет на пианино. Услышав эту подсказку, А сообщает В возраст всех
трех его детей. Сколько лет детям?
7
8.
Поменять местами имена David и Alice.Поместить имя Carol между именами Alice и David.
Поместить имя ВоЬ между именами Alice и Carol.
Нисходящее
проектирование состоит в
пошаговой детализации
(декомпозиции,
разложении) задачи на
подзадачи.
Восходящее
проектирование
–
методика, при которой
крупные
блоки
собираются из ранее
созданных мелких блоков
8
9.
Линейные алгоритмические конструкцииКоманда 1
Команда 2
Команда 3
Пример.
Определить значение целой
переменной n после выполнения следующего
алгоритма:
m := 3
n := 4
m := 6 + m*n
n := n + m/3
Решение. Первые две команды присваивания
определяют начальные значения переменных.
Для выполнения третьей команды сначала надо
вычислить правую часть выражения: 6 + 3 х 4 =
18 Это значение будет присвоено переменной
m. Для выполнения последней команды также
сначала вычисляется правая часть выражения:
4 + 18/3 = 10.
Результат будет присвоен переменной п.
Ответ: 10
9
10.
Алгоритмические конструкции ветвления10
11.
1112.
1213.
Циклические конструкцииСтруктура цикла типа while
Структура цикла типа repeat
while (условие):
действие
13
14.
while (есть еще элементы для анализа):…
выбрать следующий элемент списка
f o r Элемент i n Список:
…
Сумма = 0
f o r Число i n Список:
Сумма = Сумма + Число
14
15.
Алгоритм сортировки методом вставкиFred
Alex
Diana
Byron
Carol
Alex
Fred
Diana
Byron
Carol
15
16.
1617.
переместить опорный элемент во временное хранилище,оставив в списке пустое место
while (над пустым местом есть имя and
оно по алфавиту размещается ниже опорного элемента):
переместить имя, находящееся над пустым местом, вниз,
оставив в его прежней позиции пустое место
поместить опорный элемент на пустое место в списке
N=2
while (значение N не превышает длину списка):
выбрать N-й элемент списка в качестве опорного элемента
.
.
.
N=N+1
17
18.
def Сортировка (Список):N=2
while ( значение N не превышает длину списка) :
выбрать N-й элемент списка в качестве опорного элемента
переместить опорный элемент во временное хранилище,
оставив в списке пустое место
w h i l e ( над пустым местоместь имя a n d
оно по алфавиту размещается ниже опорного элемента):
переместить имя, находящееся над пустым местом, вниз,
оставив в его прежней позиции пустое место
поместить опорный элемент на пустое место в списке
N =N + 1
18
19.
1920.
Рекурсивные структуры20
21.
2122.
2223.
2324.
2425.
2526.
Эффективность и правильность1. пространственная эффективность (память);
2. временная эффективность;
3. интеллектуальная сложность.
26