36580

Композиция условий и операторов. Оператор условного перехода

Контрольная

Информатика, кибернетика и программирование

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

Русский

2013-09-22

32.5 KB

1 чел.

Композиция условий и операторов. Оператор условного перехода.

1. Композиция условий и операторов.

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

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

операторы условного перехода (if-then-else и if-then) и

операторы итерационных циклов (while- do и repeat-until).

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

2. Операторы условного перехода.

Операторы условного перехода имеют следующую синтаксическую структуру:

if <условие> then <оператор 1> else <оператор 2>;

if <условие> then <оператор >;

Оператор if-then-else выполняется следующим образом: вначале вычисляется значение условия (проверяется условие). Если это значение true - выполняется оператор1, а если значение условия равно false - выполняется оператор2. В качестве оператора1 или оператора2 может быть любой оператор Паскаля (простой или сложный), однако это должен быть один оператор. Если по логике алгоритма необходимо выполнить последовательность из нескольких операторов вместо оператора1 или оператора2, то должен быть использован составной оператор, образуемый заключением последовательности операторов в операторные скобки begin end. Скобки begin end превращают любую последовательность операторов в один оператор.

Оператор if-then является сокращенной формой условного оператора, рассчитанного на тот случай, когда в ветви else используется пустой оператор.

Пустой оператор является одним из простых операторов: он не производит никаких действий и обозначается точкой с запятой (;).

Замечание После оператора ветви then (перед ключевым словом else) не должна стоять точка с запятой, т.к. она будет восприниматься как дополнительный (пустой) оператор, что нарушит синтаксическую структуру оператора if-then-else!

В качестве оператора1 или оператора2 в if-then-else может быть использован другой оператор if-then-else. Это - случай вложенных операторов if-then-else. Вложенные операторы if-then-else существенно усложняют читаемость программы, они могут также приводить к неоднозначности их чтения, поэтому следует по возможности избегать использования вложенных операторов if-then-else. Во многих случаях они могут быть заменены оператором выбора из нескольких альтернатив, который мы рассмотрим позднее.

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

Оператор goto относится к числу нежелательных для использования операторов, т.к. способен серьёзно усложнить структуру программы, сделав её подобной "блюду спагетти". По этой причине мы не останавливаемся подробнее на этом операторе. Практически во всех случаях можно избежать использования goto , получая хорошо структурированные программы. Исключение составляет только безусловные переходы, для которых в Турбо Паскале предусмотрены специальные формы:

переход к концу программы - halt;

выход из процедуры или функции - exit;

выход из цикла - break;

переход к началу цикла - continue.

Задача 4.2.6(18)

program Project18;

type mas=array[1..4,1..5] of Integer;

mass=array[1..5] of real;

var a:mas;

b:mass;

i,j:Integer;

procedure p(x:mas; e:Integer; var y:real);

var i,min,max:Integer;

begin

min:=x[1,e];

max:=x[1,e];

for i:=2 to 4 do

begin

if x[i,e]<min then

min:=x[i,e];

if x[i,e]>max then

max:=x[i,e];

end;

y:=(min+max)/2;

end;

begin

for i:=1 to 4 do

for j:=1 to 5 do

read(a[i,j]);

for i:=1 to 5 do

begin

p(a,i,b[i]);

write(b[i]:5:2,' ');

end;

 Readln;

Readln;

end.


 

А также другие работы, которые могут Вас заинтересовать

77218. Создание физически-корректного дождя и сопутствующих эффектов 5.78 MB
  Целью курсовой работы была разработка и реализация дешевых, с точки зрения вычислений, но мощных алгоритмов визуализации как непосредственно самого дождя, так и различных эффектов его сопровождающих.
77219. Расширение функциональности графического редактора языка DRL 474.5 KB
  Сейчас большинство организаций разрабатывают семейства продуктов, и только немногие системы или продукты остаются уникальными. Похожая ситуация и в программной инженерии - рынок требует всё большего качества программных продуктов, уменьшения времени выхода на рынок и уменьшения их цены.
77220. Поиск оптимального ректификационного преобразования 673.5 KB
  В задаче восстановления трёхмерных сцен по двум изображениям, взятых с различных точек одним из главных этапов является поиск соответствующих точек на этих изображениях. Поиск производится вдоль эпиполярных прямых, и удобным для вычислений является случай...
77221. Массовая задача построения маршрутов движения судов 222.21 KB
  В данной работе рассматривалась следующая постановка задачи: Пространство представляет собой плоскость препятствиями являются многоугольники полученные сечением рельефа морского дна на глубине соответствующей осадке судна.
77222. МОДУЛЬНАЯ ПЛАТФОРМА ДЛЯ РАСПОЗНАВАНИЯ АВТОМОБИЛЬНЫХ НОМЕРОВ 253 KB
  Цель работы – разработка модульной платформы для последущего создания и подключения модулей, осуществляющих распознавание автомобильного регистрационного знака на полученном локализованном изображении.
77223. Конвертор приложений Windows Forms в приложения Silverlight 268.5 KB
  Первый интернет-сайт был запущен Тимом Бернерс-Ли в 1991 году. Вряд ли кто-то догадывался, какой потенциал заключало в себе это событие. Теперь стало возможно обмениваться гипертекстовыми документами. Любой пользователь Сети мог щелкнуть на ссылке, и сервер выдавал ему требуемый документ.
77224. Расширение функциональности Entity Framework 96 KB
  Документы, обрабатываемые приложением, удовлетворяют единому американскому стандарту и предполагают, что в будущем приложение будет использоваться в ряде американских клиник и интегрироваться в существующую систему документооборота.
77225. Разработка SIP телефонии для операционной системы Google Android 511.42 KB
  Целью курсовой работы является создание SIP клиента для мобильной операционной системы Android. С клиента необходимо иметь возможность совершать звонки по протоколу SIP, а также обычные GSM звонки.
77226. Интеграция технологии DocLine с системой разработки документации Adobe FrameMaker 405.5 KB
  Цель данного проекта - разработать и реализовать плагин к Adobe FrameMaker, предоставляющий конечному пользователю удобный инструментарий среды FrameMaker для работы с технологией DocLine.