- Величина сопротивления равна нулю?
- Ответ правильный?
- Сумма покупки больше 300 рублей?
В программе условие — это выражение логического типа (Boolean), которое может принимать одно из двух значений: True (истина) или False (ложь).
Простое условие состоит из двух операндов и оператора сравнения. В общем виде условие записывается следующим образом:
Оn1 Оператор On2
где:
- On1 и Оп2 — операнды условия, в качестве которых может выступать переменная, константа, функция или выражение;
- Оператор — оператор сравнения.
В языке Delphi есть шесть операторов сравнения, которые приведены в табл. 2.1.
Таблица 2.1. Операторы сравнения
Оператор |
Описание |
Результат сравнения |
||
> |
Больше |
True, если первый операнд больше второго, иначе False |
||
< |
Меньше |
True, если первый операнд меньше второго, иначе False |
||
= |
Равно |
True, если первый операнд равен второму, иначе False |
||
Оператор |
Описание |
Результат сравнения |
||
|
Не равно |
True, если первый операнд не равен второму, иначе False |
||
>= |
Больше или равно |
True, если первый операнд больше или равен второму, иначе False |
||
<= |
Меньше или равно |
True, если первый операнд меньше или равен второму, иначе False |
||
Ниже приведены примеры условий:
Summa = HBound Sim = Chr(13)
В
первом примере операндами условия является переменная и константа.
Значение этого условия зависит от значения переменной Summa. Условие
будет верным и, следовательно, иметь значение True, если значение
переменной Summa меньше, чем 1000. Если значение переменной Summa
больше или равно юоо, то значение этого условия будет False.
Во
втором примере в качестве операндов используются переменные. Значение
этого условия будет True, если значение переменной Score больше или
равно значению переменной HBound.
В
третьем примере в качестве второго операнда используется функция.
Значение этого условия будет True, если в переменной Sim находится
символьный код клавиши , равный 13.
При
записи условий следует обратить особое внимание на то, что операнды
условия должны быть одного типа или, если тип операндов разный, то тип
одного из операндов может быть приведен к типу другого операнда.
Например, если переменная Key объявлена как integer, то условие
Key = Chr(13)
синтаксически неверное, т. к. значение возвращаемое функцией Chr имеет тип char (символьный).
Во
время трансляции программы при обнаружении неверного условия
компилятор выводит сообщение: incompatible types (несовместимые типы).
Из
простых условий при помощи логических операторов: and — "логическое
И", or -- "логическое ИЛИ" и not - "отрицание" можно строить сложные
условия.
В общем виде сложное условие записывается следующим образом:
условие1 оператор условие2
где:
- условие1 и условие2 — простые условия (выражения логического типа);
- оператор — оператор and или or.
Например:
(ch >= '0') and (ch <= '9')
(day = 7) or (day = 6)
(Forml.Editl.Text ' ' ) or (Forml.Edit2.Text '' )
Forml.CheckBoxl.Checked and (Forml.Editl.Text '' )
Результат выполнения логических операторов and, or и not представлен в табл. 2.2.
Таблица 2.2. Выполнение логических операций
Op1 |
Op2 |
Opt and Op2 |
Op1 or Op2 |
not Op1 |
||
False |
False |
False |
False |
True |
||
False |
True |
False |
True |
True |
||
True |
False |
False |
True |
False |
||
True |
True |
True |
True |
False |
||
При
записи сложных условий важно учитывать то, что логические операторы
имеют более высокий приоритет, чем операторы сравнения, и поэтому
простые условия следует заключать в скобки.
Например,
пусть условие предоставления скидки сформулировано следующим образом:
"Скидка предоставляется, если сумма покупки превышает 100 руб. и день
покупки — воскресенье", Если день недели обозначен как переменная Day
целого типа, и равенство ее значения семи соответствует воскресенью, то
условие предоставления скидки можно записать:
(Summa > 100) and (Day = 7)
Если
условие предоставления скидки дополнить тем, что скидка
предоставляется в любой день, если сумма покупки превышает 500 руб., то
условие можно записать:
((Summa > 100) and (Day =7)) or (Summa > 500)
Инструкция if позволяет выбрать один из двух возможных вариантов развития программы. Выбор осуществляется в зависимости от выполнения условия.
В общем виде инструкция if записывается так:
if условие then
begin
// здесь инструкции, которые надо выполнить,
// если условие истинно.
end
else
begin
// здесь инструкции, которые надо выполнить, // если условие ложно. end;
Обратите внимание, что перед else (после end) точка с запятой не ставится.
Выполняется инструкция if следующим образом:
1. Вычисляется значение условия (условие — выражение логического типа, значение которого может быть равно True или False).
2. Если условие истинно (значение выражения условие равно
True), то выполняются инструкции, следующие за словом then (между
begin и end). На этом выполнение операции if заканчивается, то есть
инструкции, следующие за else, не будут выполнены.
Если условие ложно (значение выражения условие равно False), то выполняются инструкции, следующие за словом else (между begin и end).
Например,
если переменная t обозначает тип соединения сопротивлений в
электрической цепи (t=1 соответствует последовательному соединению, t=2
— параллельному), a r1 и r2 — величины сопротивлений, то приведенная
ниже инструкция if осуществляет выбор формулы, по которой будет
выполнен расчет.
if t=l then
begin
z:=r1+r2;
end
else
begin
z:=(r1+r2)/(r1*r2);
end;
Если в инструкции if между begin и end находится только одна инструкция, то слова begin и end можно не писать.
Например, инструкцию
if otv=3
then
begin
prav:=prav+1 ;
end
else
begin
ShowMessage('Ошибка!');
end;
можно переписать так:
if otv=3 then
prav:=prav+l
else
ShowMessage('Ошибка!') ;
Если
какое-либо действие должно быть выполнено только при выполнении
определенного условия и пропущено, если это условие не выполняется, то
инструкция if может быть записана так:
if условие then
begin
{ инструкции, которые надо выполнить, если условие выполняется, истинно } end
На рис. 2.3 представлен алгоритм, соответствующий инструкции if-then.
if n=m
then c:=c+l;
увеличивает значение переменной с только в том случае, если значения переменных n и m равны.