Лекция 6. Сложные
операторы ТР.
1.
Элементы структурного программирования.
1. Элементы структурного
программирования.
Структурированная программа (или
подпрограмма) - это программа,
составленная из фиксированного множества базовых конструкций. Рассмотрим основные определения и способы образования этих
конструкций в схемах алгоритмов.
Из операций, развилок и слияний строятся
базовые конструкции: следование, ветвление,
цикл. Применяя только эти три конструкции, можно
реализовать алгоритм
решения любой задачи.
Конструкция, представляющая собой
последовательное выполнение двух
или более операций,
называется следованием.
Конструкция, состоящая из развилки, двух
операций и слияния, называется ветвлением. Одна из операций может
отсутствовать.
Конструкция, имеющая линии управления,
ведущие к предыдущим операциям или развилкам, называется циклом.
Конструкции следование, ветвление
и цикл можно представить как
операции, так как они имеют единственный
вход и единственный выход.
Произвольную
последовательность операций можно
представить как одну
операцию.
Операция может быть
реализована любым оператором языка ПАСКАЛЬ
(простым
или составным), либо группой операторов, за исключением оператора перехода
GOTO.
В языке ПАСКАЛЬ количество базовых
конструкций увеличено до шести,
это:
1. -следование;
2. -ветвление;
3. -цикл с предусловием;
4. -цикл с постусловием;
5. -цикл с параметром;
6. -вариант.
Далее рассмотрим, как эти базовые конструкции реализуются в
языке ПАСКАЛЬ.
Условный оператор используется в
программе для реализации алгоритмической структуры – ветвления. В данной
структуре вычислительный процесс может продолжаться по одному из возможных
направлений. Выбор направления обычно осуществляется проверкой какого-либо
условия. Существует два вида структуры ветвления: структура вилка и обход.
В языке Паскаль условный оператор IF это
средство организации ветвящегося вычислительного процесса.
Формат: IF [логическое_выражение]
Then [оператор_1]; Else
[оператор_2];
IF,
Then, Else – служебные слова. [оператор_1], [оператор_2] –
обыкновенные операции языка Паскаль. Часть Else
является необязательной (может отсутствовать).
Оператор IF работает следующим образом:
вначале проверяется результат логического выражения. Если результат
Истина(TRUE), то выполняется [оператор_1], следующий за служебным словом Then, а [оператор_2] пропускается. Если результат
Ложь(FALSE), то [оператор_1] пропускается, а [оператор_2] исполняется.
Если часть Else
отсутствует, то оператор IF имеет не полную форму:
IF [логическое_выражение]
Then [оператор];
В этом случае, если результат
Истина(TRUE), то выполняется [оператор], если Ложь(FALSE), то управление
передается оператору, следующему за оператором IF.
Пример использования оператора IF:имеются 2 числа A и B. Найти максимальное
число.
Составной оператор – это
последовательность произвольных операций в программе, заключенная в так называемые
операторные скобки (Begin-End).
Формат: Begin
[операторы]; End;
Составные операторы позволяют
представлять группу операторов, как один оператор.
Предназначен для реализации
множественных ветвлений, поскольку оператор IF может реализовать всего два
направления вычислительного процесса, использовать его для реализации
множественных ветвлений не всегда удобно. Множественное ветвление реализуется
оператором CASE.
Формат: CASE [ключ_выбора]
OF
[константа_выбора_1]:[оператор_1];
[константа_выбора_2]:[оператор_2];
…
[константа_выбора_N]:[оператор_N];
ELSE
[оператор];
End;
CASE, OF, ELSE, END – служебные слова. [ключ_выбора]
– это параметр одного из порядковых типов. [константы_выбора] – константы того
же типа, что и ключ выбора, реализующие выбор. [оператор_1(N)] – обыкновенный
оператор. ELSE может отсутствовать.
Оператор выбора работает следующим
образом: до работы оператора определяется значение параметра ключ выбора. Этот
параметр может быть либо выражен как переменная в программе, либо другим путем.
Затем параметр ключ выбора последовательно сравниваем с константой выбора. При
совпадении значения ключа выбора с одной из констант выбора, выполняется
оператор, следующий за этой константой, а все прочие операторы игнорируются. В
случае не совпадения ключа выбора ни с одним из констант, выполняется оператор,
следующий за Else. Часто Else
является не обязательной и в случае несовпадения ключа выбора ни с одной из
констант выбора и при отсутствии Else, управление
передается оператору, следующему за оператором CASE.
В операторе CASE нет явной проверки
условия, характерного для оператора IF. В тоже время в неявном виде операция
сравнения выполняется. CASE вносит диссонанс в программу на языке Паскаль,
поскольку данные оператор завершается служебным словом End,
которому нет парного Begin.
Пример использования оператора CASE: составить алгоритм и программу
задачи, моделирующей работу светофора. При вводе символа первой буквы цветов
светофора, программа должна выводить сообщение о соответствующем цвете и
действиях.
Программа работает следующим образом: с
клавиатуры процедурой Read вводится символ буквы
цвета светофора. Если введена буква ‘з’
соответствующая зеленому цвету, то в операторе CASE введено значение в списке
выбора найдет константу выбора ‘з’ и будет выведено
сообщение “Зеленый цвет, движение разрешено”. При вводе символа букв ‘к’ и ‘ж’
буду выведены аналогичные сообщения. При вводе любого другого символа будет
выведено сообщение “Светофор не работает”, поскольку в этом случае работает
часть Else, оператора CASE.
Циклической алгоритмической структурой
считается такая структура, в которой некоторые действия выполняются несколько раз.
В программировании имеются два вида циклических структур: цикл с параметром и
итерационный цикл.
В цикле с параметром всегда имеются так
называемые параметры цикла: X, Xn, Xk, ∆X. Иногда цикл с параметром называют
регулярным циклом. Характерной чертой является то, что число циклов и
повторений можно определить до выполнения цикла.
В итерационном цикле невозможно
определить число циклов до его выполнения. Он выполняется до тех пор, пока
выполняется условие продолжение цикла.
В языке Паскаль имеются три оператора,
реализующих циклические вычислительные структуры:
Последние два ориентированы на
реализацию итерационного цикла, однако их можно использовать и для реализации
цикла с параметром.
Формат: FOR [параметр_цикла]
:= [н_з_п_ц] To [к_з_п_ц] Do
[оператор];
FOR, To, Do – служебные слова. [параметр_цикла]
– параметр цикла. [н_з_п_ц]
– начальное значение параметра цикла. [к_з_п_ц] –
конечное значение параметра цикла. [оператор] – произвольный оператор.
Параметр цикла должен быть переменой
порядкового типа. Начальное и конечное значения параметра цикла должны быть
того же типа, что и параметр цикла.
Работу оператора рассмотрим на его
алгоритме:
На первом шаге значение параметра цикла
принимает [н_з_п_ц], затем
осуществляется проверка параметр цикла меньше или равен [к_з_п_ц].
Это условие является условием продолжения цикла. Если выполнено, то цикл
продолжает свою работу и выполняется [оператор], после чего параметр цикла
увеличивается (уменьшается) на единицу. Затем с новым значением параметр цикла,
проверяется условие продолжения цикла. Если оно выполняется, то действия
повторяются. Если условие не выполняется, то цикл прекращает свою работу.
Оператор For
существенно отличается от аналогичных операторов в других языках
программирования. Отличия следующие:
Пример использования оператора FOR: составить таблицу перевода рублей
в доллары.
Формат: WHILE [условие] Do [оператор];
WHILE, Do –
служебные слова. [условие] –
выражение логического типа. [оператор] – обыкновенный оператор.
;
Оператор While
работает следующим образом: вначале работы проверяется результат логического
условия. Если результат истина, то выполняется оператор, после которого
осуществляется возврат на проверку условия с новым значением параметров в
логическом выражении условия. Если результат ложь, то осуществляется завершение
цикла.
При работе с While
надо обратить внимание на его свойства:
Пример использования оператора WHILE: вычислить y=sin(x), где xn=10, xk=100, шаг равен 10.
Формат: REPEAT [тело_цикла];
UNTIL [условие];
Оператор REPEAT работает следующим
образом: сначала выполняются операторы тела цикла, после чего результат проверяется
логического условия. Если результат ложь, то осуществляется возврат к
выполнению операторов очередного тела цикла. Если результат истина, то оператор
завершает работу.
Оператор Repeat
имеет следующие особенности:
Пример использования оператора REPEAT: вычислить y=sin(x), где xn=10, xk=100, шаг равен 10.