Алгоритмы. Свойства алгоритмов. Исполнители презентация

Содержание

Слайд 2

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

от исходных данных к искомому результату.

Алгоритм

Слайд 3

Понятность – каждый шаг представлен в форме, понятной исполнителю (на его языке).
Дискретность –

разбиение на отдельные элементарные шаги.
Однозначность - детерминированность, определённость формулировок, не допускающая разных толкований (исполнителю должно быть точно понятно, какой шаг выполнять дальше).

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

Слайд 4

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

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

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

Слайд 5

словесный;
табличный;
графический;
программа на алгоритмическом языке.

Способы записи алгоритмов

Слайд 6

Иногда алгоритмы записывают не на естественном, а формальном языке. Так, например, в решении

шахматной задачи вместо фразы “Конь, находящийся на поле d5, берет фигуру на поле f6 и объявляет шах” пишут “Кd5:f6+”.
Формализованная запись алгоритма понятна меньшему количеству исполнителей, но она обеспечивает краткость и недвусмысленность, облегчая тем самым задачу исполнения алгоритма.

Способы записи алгоритмов

Слайд 7

Графическая форма записи алгоритма более наглядна, чем словесная. Распространенным графическим способом представления алгоритмов

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

Способы записи алгоритмов

Слайд 8

Начало- конец

Ввод-вывод данных

Принятие решения
(проверка условия)

Действие, операция

Обозначение в блок-схемах

Слайд 9

Исполнитель алгоритма - человек и/или автоматическое устройство: - понимающий язык, на котором записан

алгоритм; и - способный выполнить этот алгоритм.

Исполнитель алгоритма

Слайд 10

Исполнителем алгоритма может быть не только человек, но и автоматическое устройство (реальное или

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

Кто может быть исполнителем алгоритма?

Слайд 11

Разрабатывает алгоритмы: человек,
Исполняют алгоритмы: люди и устройства – компьютеры, роботы, станки, спутники,

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

Разработка и исполнение

Слайд 12

Системой команд Исполнителя называется совокупность всех команд, которые может выполнить Исполнитель.
Совокупность всех

действий, которые он может выполнить в ответ на эти команды, называется системой допустимых действий Исполнителя.
Среда – это обстановка, в которой работает исполнитель
Элементарное действие – действие, совершаемое исполнителем после вызова команды.
Отказы. Возникают при вызове команды в недопустимом для данной команды состоянии среды.

Исполнителя характеризует:

Слайд 13

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

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

Что такое псевдокод?

Слайд 14

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

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

Что такое псевдокод?

Слайд 15

Примером псевдокода является школьный алгоритмический язык в русской нотации (школьный АЯ). Этот язык

в дальнейшем мы будем называть просто "алгоритмический язык".

Что такое псевдокод?

Слайд 16

Как записываются алгоритмы на школьном алгоритмическом языке? Основные служебные слова

алг (алгоритм)
сим (символьный)
арг (аргумент)
лит (литерный)
рез (результат)
лог (логический)
нач (начало)
таб(таблица)
кон (конец)
нц (начало цикла)
цел (целый)
кц (конец цикла)
вещ (вещественный)
длин (длина)

Слайд 17

Как записываются алгоритмы на школьном алгоритмическом языке? Основные служебные слова

дано
для
да
надо
от
нет
если
до
при
то
знач
выбор
иначе
и
ввод
все
или
вывод
пока
не
утв

Слайд 18

Общий вид алгоритма:
алг название алгоритма (аргументы и результаты)
дано условия применимости

алгоритма
надо цель выполнения алгоритма
нач описание промежуточных величин
| последовательность команд (тело алгоритма)
кон

Как записываются алгоритмы на школьном алгоритмическом языке?

Слайд 19

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

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

Как записываются алгоритмы на школьном алгоритмическом языке?

Слайд 20

Команда присваивания. 
Служит для вычисления выражений и присваивания их значений переменным.
Общий вид:  А:=В


знак  ":="  означает команду заменить прежнее значение переменной, стоящей в левой части, на вычисленное значение выражения, стоящего в правой части. 
Например,   a := (b+c) * sin(Pi/4);   i := i+1.

Команды школьного АЯ

Слайд 21

Команды ввода и вывода.
ввод  имена переменных
вывод  имена переменных,
выражения, тексты.
Команды

если и выбор.  Применяют для организации ветвлений.
Команды для и пока. Применяют для организации циклов.

Команды школьного АЯ

Слайд 22

алг Сумма квадратов (арг цел n, рез цел S)
дано | n

> 0
надо | S = 1*1 + 2*2 + 3*3 + ... + n*n
нач цел i
ввод n; S:=0
нц для i от 1 до n
S:=S+i*i
кц
вывод "S = ", S
кон

Пример записи алгоритма на школьном АЯ

Слайд 23

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

данное понятие из других понятий и букв алфавита,
а семантические правила определяют свойства данного понятия.

Какие понятия используют алгоритмические языки?

Слайд 24

Основными понятиями в алгоритмических языках обычно являются следующие.
 Имена (идентификаторы) — употpебляются для обозначения объектов пpогpаммы (пеpеменных,

массивов, функций и дp.).
Опеpации. Типы операций:
аpифметические опеpации + , —, *, / и дp. ;
логические опеpации   и, или, не  ;

Какие понятия используют алгоритмические языки?

Слайд 25

опеpации отношения   < ,>,<=,>= ,=, <>;
опеpация сцепки (присоединения) символьных значений дpуг с другом с образованием одной

длинной строки; изображается знаком "+«.

Какие понятия используют алгоритмические языки?

Слайд 26

Данные — величины, обpабатываемые пpогpаммой. Имеется тpи основных вида данных: константы, пеpеменные и массивы.
Константы — это данные,

которые зафиксированы в тексте программы и не изменяются в процессе ее выполнения. Пример: да(истина); 7.5; «+»; «мир»

Какие понятия используют алгоритмические языки?

Слайд 27

Пеpеменные обозначаются именами и могут изменять свои значения в ходе выполнения пpогpаммы. Пеpеменные бывают целые,

вещественные, логические, символьные и литерные.

Какие понятия используют алгоритмические языки?

Слайд 28

Массивы — последовательности однотипных элементов, число которых фиксировано и которым присвоено одно имя. Положение

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

Какие понятия используют алгоритмические языки?

Слайд 29

 Выpажения — пpедназначаются для выполнения необходимых вычислений, состоят из констант, пеpеменных, указателей функций (напpимеp,

exp(x)), объединенных знаками опеpаций.
Выражения записываются в виде линейных последовательностей символов (без подстрочных и надстрочных символов, "многоэтажных" дробей и т.д.), что позволяет вводить их в компьютер, последовательно нажимая на соответствующие клавиши клавиатуры.
Различают выражения арифметические, логические и строковые.

Какие понятия используют алгоритмические языки?

Слайд 30

 Арифметические выражения служат для определения одного числового значения.  Например,  (1+sin(x))/2. Значение этого выражения при

x=0 равно 0.5,  а при x=p/2 — единице.
Логические выражения описывают некоторые условия, которые могут удовлетворяться или не удовлетворяться. Таким образом, логическое выражение может принимать только два значения —  "истина"  или  "ложь"  (да  или  нет). Рассмотрим в качестве примера логическое выражение  x*x + y*y < r*r ,  определяющее принадлежность точки с координатами  (x, y)  внутренней области круга радиусом  r  c центром в начале координат.  При  x=1,  y=1,  r=2 значение этого выражения —  "истина", а при  x=2,  y=2,  r=1  — "ложь".
Cтроковые (литерные) выражения, значениями которых являются текcты. В строковые выражения могут входить литерные и строковые константы, литерные и строковые переменные, литерные функции, разделенные знаками операции сцепки. Например, А + В означает присоединение строки  В  к концу строки  А . Если А = "куст ", а В = "зеленый", то значение выражения А + В есть   "куст зеленый".

Какие понятия используют алгоритмические языки?

Слайд 31

Базовая структура  "следование". Образуется последовательностью действий, следующих одно за другим:
Базовая структура  "ветвление". Обеспечивает в

зависимости от результата проверки условия (да или нет) выбор одного из альтернативных путей работы алгоритма. Каждый из путей ведет к общему выходу, так что работа алгоритма будет продолжаться независимо от того, какой путь будет выбран. Структура ветвление существует в четырех основных вариантах:

Базовые алгоритмические структуры

Слайд 32

если—то;
если—то—иначе;
выбор;
выбор—иначе.

Базовые алгоритмические структуры

Слайд 33

Базовая структура  "цикл". 
Обеспечивает многократное выполнение некоторой совокупности действий, которая называется телом цикла.

Базовые алгоритмические структуры

Слайд 34

Примеры структуры ветвление

базовые алгоритмические структуры

Слайд 35

Примеры структуры ветвление

базовые алгоритмические структуры

Слайд 36

Примеры структуры ветвление

базовые алгоритмические структуры

Слайд 37

Примеры структуры цикл

Имя файла: Алгоритмы.-Свойства-алгоритмов.-Исполнители.pptx
Количество просмотров: 19
Количество скачиваний: 0