Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Правила записи и выполнения




1. Метка m задаётся пользователем.

2. Оператор, помеченный меткой m, в соответствии с требованиями алгоритма, может располагаться как выше, так и ниже оператора if.

3. При выполнении проверяемого условия (результат - ИСТИНА) управление передаётся оператору goto, который в свою очередь передаёт управление оператору, помеченному меткой m

4. Если результат проверки есть ЛОЖЬ, управление передаётся оператору, записанному непосредственно под if.

Схема выполнения:

 

if(B) goto m;

Ветвь_НЕТ;

m:...

 

if(.9>=c) goto m4;

y2=15;

n=2;

m4: z=10.;

Полный оператор условного перехода

 

Структура оператора:

if(P) ветвь_ДА

[ else

ветвь_НЕТ]

if, else- ключевые слова (если, иначе);

P- выражение, подлежащее проверке;

()- ограничители Р;

ветвь_ДА - последовательность операторов, соответствующих вы­полнению проверяемого условия;

ветвь_НЕТ - простой (составной) оператор, соответствующий невы­полнению проверяемого условия;

[]- признак необязательности содержимого

 

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

· вычисляется выражение Р:

· если Р истинно, выполняются операторы ветви «ДА» и управление ^5дередаётся оператору, записанному под ветвью «НЕТ»;

· если Р ложно, выполняются операторы ветви «НЕТ», а затем оператор, расположенный под этой ветвью,

 

 

Так, фрагмент программы

if(a<d) предписывает проверку логического условия а<=<1
y1=s; и, при выполнении его, вычисление у!=5, а затем
n=1; z=к. Если же проверяемое условие не выполняется
y1=1.7; (а>d), будет вычислен у1=1.7, а затем z=k.

z=k;

 

Правила записи и использования

 

1. Отсутствие указанных в квадратных скобках элементов приводит к получению укороченного (неполного) оператора условного перехода.

2. В ветви «ДА» количество простых операторов может быть любым. одна ко желательно их оформление в виде одного составного.

3. В ветви «НЕТ» должен быть только один простой (составной) оператор

4. В каждой из ветвей возможно использование других операторов if для проверки дополнительных условий. В этом случае говорят о вложенных операторах if. При записи вложенных if рекомендуется для наглядности сдвигать их вправо от основного.

 

Множественное ветвление

Для организации ветвления типа «выбор» с любым числом ветвей в зависимости от значения проверяемого целочисленного операнда (выражения), в Си существует специальная конструкция из двух операторов - переключатель (switch) и разрыв (bгеаk). Структура конструкции:

 

switch (выражение) {

саsе n1:

оператор 1; [bгеаk;]

...

саsе ni:

оператор i; [bгеаk;]

...

саsе nN:

оператор N; [bгеаk;]

 

[defaul:

оператор N+1;] }

 

где switch - (переключатель) ключевое слово, название основного оператора;

выражение - любое с целочисленным результатом;

() - ограничители выражения;

саsе - (вариант) ключевое слово;

n1...ni…nN - целая (символьная) константа (метка), обозначаю­щая требуемый вариант;.

: - признак метки;

 

оператор i; - совокупность (начиная с нуля) простых оператореов,

соответствующих каждому варианту выбора;

default - (по умолчанию) ключевое слово;

{} - оганичители тела оператора switch;

[] - признак необязательности содержимого;

bгеаk; - вспомогательный оператор (разорвать, выйти).

 

Оператор работает следующим образом

· вычисляется значение выражения переключения. Результат – целая (символьная) константа;

· результат последовательно сравнивается с каждой из меток ni в диапазоне от n1 до nМ;

· если совпадение с одной из меток ni произошло, выполняется соответствующий оператор (i) и оператор bгеаk;, если он имеется, передаёт управление оператору программы, расположенному под закрывающей фигурной скобкой. (При отсутствии bгеаk после оператора i сохраняется естественный выполнения ниже записанных операторов, начиная с (i+1)

· если метки ni, аналогичной результату вычисления выражения не обнаружено и элемент по умолчанию (default: оператор N+1;) присутствует, управление передается оператору N+1, а затем оператору, расположенному под закрывающей фигурной скобкой. (При отсутствии элемента по умолчанию управление напрямую передается оператору под фигурной скобкой)

 

Так, фрагменты программ

 

int i; int i;

......

switch(i) switch(i)

{ {

саsе 1: х=1; саsе 1: х=1;

bгеаk; bгеаk;

саsе 2: у=7; саsе 2: у=7;

bгеаk; bгеаk;

саsе 6: z=15; саsе 6: z=15;

bгеаk; bгеаk;

default: }

t=0; s=3;

}

s=3;

 

предписывают вычисление х, если i = 1, вычисление, у, если i = 2, вычисление z при i = 6, а затем передачу управления на вычисление переменной 5. Если же

i ¹ 1, 2, 6, то в левом фрагменте будут вычислены t и z, а в правом фрагменте - только s.

 

Правила составления и использования

1. Метки ni задаются пользователем произвольно (желательно по нарастанию) и не могут повторяться.

2. В одном операторе switch может быть не более 257 вариантов выбора.

3. Отсутствие операторов bгeak позволяет получить чистую структуру оператора switch. В этом варианте после выбора нужной ветви будут последовательно выполнены все ниже расположенные варианты, включая default, если он имеетется.

4. Элемент по умолчанию может быть не последним в теле оператора switch. При этом, если оператор bгeak в его ветви отсутствует, то будут последовательно выполнены все ниже расположенные варианты.

5. Использование чистого оператора switch при отсутствии некоторых операторов ветвей позволяет выполнять передачу управления на одну ветвь по нескольким разным меткам, записанным выше.

6. Метками оператора goto помечать ключевые слова саsе и default запрещается, т.к. они сами выполняют функцию меток.

 




Поделиться с друзьями:


Дата добавления: 2014-01-07; Просмотров: 288; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.019 сек.