Понятие алгоритма. Свойства алгоритма

Понятие алгоритма

1. Определение

Что такое алгоритм? Если посмотреть вокруг, то практически все происходящие процессы выполняются по своему алгоритму. Строительство домов, приготовление блюда, работа банкомата и многие другие процессы имеют свой алгоритм.

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

Сам по себе алгоритм не имеет ценности, если он не будет выполнятся. Для выполнения алгоритма нужен исполнитель.

 
Исполнитель алгоритма - объект или субъект, для которого написан алгоритм.

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

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

Формальные и неформальные исполнители

Формальные исполнители Неформальные исполнители
 Имеют конечную Систему команд исполнителя. Сами отвечают за свои действия.
Одну и ту же команду выполняет одинаково. Одну и ту команду могут выполнять по разному.
Примеры Технические устройства: компьютер, калькулятор, микроволновая машина и т.п. Примеры Человек, животные

Каждый исполнитель может обладать следующими характеристиками:

  • Набор решаемых задач. Каждый исполнитель решает определенный круг задач.
  • Среда исполнителя. Окружение, при котором исполнитель выполняет команды.
  • Система команд исполнителя (СКИ) - набор команд, которые может выполнить исполнитель.
  • Система отказов исполнителя. Если команда не может быть выполнена в определенной ситуации, то должно выводится сообщение, например, "Не могу выполнить".
  • Режимы работы исполнителя. Либо выполнение каждой команды исполнителя, либо выполнение сразу целой программы. 

2. Способы представления алгоритма

Алгоритмы можно представить следующими способами:

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

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

  1. Закройте все приложения.
  2. Нажмите кнопку Пуск или нажмите комбинацию клавиш Alt+F4
  3. Выберите Выключение - Завершение работы

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

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

Например, алгоритм открытия двери будет записан в следующем виде:

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

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

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

нач

ввод Длина стороны квадрата a

S = 4a

вывод Площадь квадрата S

кон

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

Например, алгоритм вычисления площади квадрата на языке Python будет записан в следующем виде:

print("Введите длину стороны квадрата")

а = int(input())

S = 4 * a

print("Площадь квадрата =", S)

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

ДискретностьАлгоритм должен представлять процесс решения задачи как последовательность простых шагов;

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

Понятность. Алгоритм должен включать только команды, которые может выполнить исполнитель;

Конечность. Алгоритм должен быть выполнен за конечное количество шагов;

Массовость/Универсальность. Алгоритм должен решать целый набор однотипных задач;

Результативность. Алгоритм должен приводить к получению результата.


Вопросы для самопроверки:

  1. Что такое алгоритм?
  2. Кто такой исполнитель алгоритма?
  3. Какие существуют способы представления алгоритмов?
  4. В чем разница между формальными и неформальными исполнителями?
  5. Какие свойства характеризуют алгоритм?
  6. Что такое система команд исполнителя (СКИ)?
  7. Приведите примеры формальных и неформальных исполнителей.
  8. Опишите графический способ представления алгоритма.
  9. Что означает свойство алгоритма "дискретность"?
  10. Почему важна определенность в алгоритме?

Упражнения:
Упражнение 1. "Классификация свойств алгоритмов"

 

Категория: Algorithms | Добавил: bzfar77 (21.06.2021)
Просмотров: 1358 | Теги: словесный, исполнитель алгоритма, Алгоритмический, графический, программный, Алгоритм, свойства алгоритма | Рейтинг: 5.0/3
Всего комментариев: 0
avatar