В.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль (1107618), страница 19
Текст из файла (страница 19)
Правила вычисления логического выражения впаскале не требуют в таких случаях обязательно вычислять оставшуюсячасть выражения, но и не запрещают это делать. Следовательно, при записии использовании логического выражения программист обязан позаботитьсяо том, чтобы каждый его операнд имел смысл независимо от значений других операндов во время вычисления значения этого выражения. Игнорирование этого обстоятельства может привести к ошибкам в программе.Если значение, определяемое логическим выражением, необходимо запомнить для последующего его использования в качестве значения некоторой (логической) переменной, то для этого также используется операторприсваивания, который выполняется так же, как и арифметический оператор присваивания.Примеры логических операторов присваивания:d:=trиеЬ:=<х>у>and<k*C)с:=d or b and not(odd(k)and d)4.2.3.
Литерный оператор присваиванияЕсли в левой части оператора присваивания указана переменная типа char,то в правой его части должно быть задано литерное выражение, задающееправило определения значения типа char, т.е. отдельную литеру. Как мыуже знаем из рассмотрения типа char, над значениями этого типа в паскалене определены какие-либо операции, результатом выполнения которыхтакже является значение типа char. Поэтому литерным выражением можетбыть только константа, переменная или функция этого типа.Примеры литерных операторов присваивания (sym, alpha, beta - переменные типа char):sym: = ' + 'alpha: =syitibeta:=succ(sym)Итак, мы рассмотрели все типы выражений и соответствующих им операторов присваивания для тех типов значений паскаля, с которыми мызнакомы к настоящему времени. По мере изложения других типов значенийпаскаля будут вводиться в употребление соответствующие типы выраженийи операторов присваивания.Заметим, что в языке паскаль, вообще говоря, нет таких понятий, какарифметическое выражение, логическое выражение и т.д., а имеетсятолько одно синтаксически определяемое понятие — < выражение >, в которое входят все типы выражений.
Мы ввели эти дополнительные понятияиз методических соображений.4.3. Составной операторСоставной оператор относится к числу производных операторов. Напомним, что в состав производных операторов входят другие операторы, набазе которых и строится тот или иной производный оператор.Для однозначности понимания паскаль-программы часто требуется,чтобы в том или ином месте синтаксической конструкции (например68в производном операторе) фигурировал единственный оператор, тогда какпо существу алгоритма на этом месте требуется записать некоторую последовательность операторов. Для разрешения возникающего в этом случаеконфликта между синтаксисом языка и реальной потребностью программиста в паскале и служит составной оператор, который объединяет некоторую последовательность операторов в единый оператор путем заключенияэтой последовательности в операторные скобки — служебные слова begin(начало) и end (конец) :(составной оператор > ::= begin (оператор > {; (оператор >} endКак видно из определения, последовательность операторов, объединяемая в единый (составной) оператор, может состоять и из единственногооператора.
Если же в эту последовательность входит более одного оператора, то они отделяются друг от друга точкой с запятой. Заметим, что в паскале точка с запятой используется как разделитель операторов, т.е. она не входит в предшествующий ей или следующий за ней оператор.Язык не накладывает каких-либо ограничений на операторы, входящиев составной оператор — это могут быть как основные, так и производныеоператоры, в том числе и составные операторы, так что определение составного оператора носит рекурсивный характер.Примеры составных операторов:begin i:=0 endbegin у: =x/2;x:=x+h endbegin k:=2;begin i:=0;счетчик:=0 end endВыполнение составного оператора сводится к последовательному — впорядке их написания — выполнению входящих в него операторов.С составным оператором мы фактически уже встречались: напомним,что раздел операторов в теле любой паскаль-программы есть единственныйсоставной оператор.4.4.
Условный операторВ разветвляющихся вычислительных процессах отдельные этапы вычислений (операторы) выполняются не всегда в одном и том же порядке, а взависимости от некоторых условий, проверяемых уже по ходу вычислений,выбираются для исполнения различные их последовательности. Если, например, в программе используются вещественные переменные х, у и z, ина каком-то этапе решения задачи требуется вычислить z = шах ( х , у ) , тожелаемый результат получается в результате выполнения либо оператораприсваивания z := х, либо оператора присваивания z : = у. Поскольку значения переменных х и у заранее неизвестны, а определяются в процессе вычислений, то в программе необходимо предусмотреть оба эти оператораприсваивания. Однако на самом деле должен выполняться только один изних.
Поэтому в программе должно содержаться указание о том, в к а к о мслучае надо выбирать для исполнения тот или иной оператор присваивания.Это указание естественно сформулировать с использованием отношениях > у: если это отношение при текущих значениях х и у справедливо (принимает значение t r u e ) , то для исполнения должен выбираться оператор69z := х; в противном случае для исполнения должен выбираться операторz := у (при х = у безразлично, какой оператор выполнять, так что выполнение оператора z := у в этом случае дает правильный результат).Для задания подобного рода разветвляющихся вычислительных процессов служат выбирающие операторы, которые относятся к числу производных операторов. Рассматриваемый здесь условный оператор к а к раз и относится к числу выбирающих операторов. В паскале имеются две формыусловного оператора: полная и сокращенная.
Рассмотрим сначала полныйусловный оператор:< полный условный оператор > ::= if (логическое выражение )then (оператор > else (оператор >Здесь if (если), then (то) и else (иначе) являются служебными словами.Таким образом, структуру полного условного оператора можно представить в видеif В then SI else S2где В — логическое выражение, a SI и S2 — операторы.Выполнение такого условного оператора сводится к выполнению одного из входящих в него операторов S1 или S2: если заданное в операторе условие выполняется (логическое выражение В принимает значение true), то выполняется оператор S1, в противном случае выполняетсяоператор S2.Примеры полных условных операторов:i-f х < 0 then i:=i + i else k:=»k+li-f <x<y> and d thenbegin x : =>: +h ; у: -y-h; d: =not d end elsebegin x:"=0; y:=0 endi-f <x>y) and <x>z ) then x : =0 elseif y>2 then y:=0 else г:=0Таким образом, алгоритм решения упомянутой выше задачи вычисления z = шах(х, у) можно задать в виде условного оператораi-f х >у then z : =х else z : =уПри формулировании алгоритмов весьма типичной является такая ситуация, когда на определенном этапе вычислительного процесса какиелибо действия надо выполнять только при выполнении некоторого условия, а если это условие не выполняется, то на данном этапе вообщене нужно выполнять никаких действий.
Простейшим примером такойситуации является замена текущего значения переменной х на абсолютную величину этого значения: если х < 0, то необходимо выполнить оператор присваивания х := —х; если же х > О, то текущее значение х должно остаться без изменения, т.е. на данном этапе вообще не надо выполнять каких-либо действий.В подобных ситуациях весьма удобна сокращенная форма условногооператора:(сокращенный условный оператор > ::= if (логическое выражение >then (оператор >70Правило выполнения сокращенного условногооператора, имеющего видif В then Sдостаточно очевидно: если значение логического выражения В есть true,то выполняется оператор S; в противном случае никаких иных действий, кроме вычисления выражения В, не производится.Еще раз обратим внимание на то, что в условном операторе междусимволами then и else, а также после символа else по синт; ксису может.присутствовать только один оператор.