11823

Операторы ветвления и выбора

Лабораторная работа

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

Лабораторная работа №3. Операторы ветвления и выбора 1 Цель и порядок работы Цель работы изучить операторы используемые для организации ветвления в программе. Познакомится с логическими выражениями и операциями. Порядок выполнения работы: ознакомиться с...

Русский

2013-04-12

148.5 KB

60 чел.

Лабораторная работа №3. Операторы ветвления и выбора

1 Цель и порядок работы

Цель работы – изучить операторы, используемые для организации ветвления в программе. Познакомится с логическими выражениями и операциями.

Порядок выполнения работы:

  •  ознакомиться с описанием лабораторной работы;
  •  получить задание у преподавателя, согласно своему варианту;
  •  написать программу и отладить ее на ЭВМ;
  •  оформить отчет.

2 Краткая теория

Операторы ветвления управляют  потоком  выполнения программы.  Это условный оператор if...else и переключатель switch.

Условные операторы позволяют выбрать один из вариантов выполнения действий в зависимости от каких-либо условий. Условие – это логическое выражение, т.е. выражение, результатом которого является логическое значение истина или ложь. Выражение может иметь арифметический тип. Если оно не равно 0, то условие считается истинным. Если равно 0 , то условие считается ложным.

2.1 Оператор ветвления

Оператор if выбирает один из двух вариантов последовательности вычислений. Синтаксис условного оператора:

if (выражение)

  оператор_1;

else

  оператор_2;

Рисунок 3.1 – Блок-схема оператора ветвления

Выражение должно быть скалярным и может иметь арифметический тип или тип указателя.  Если оно не равно нулю (или не  есть  пустой указатель), то  условие  считается истинным и выполняется оператор_1. В противном случае выполняется оператор_2.  В качестве операторов нельзя использовать описания и определения.

Если в случае истинности условия необходимо выполнить несколько операторов, их можно заключить в фигурные скобки (т.е. использовать составные операторы и блоки):

if (x > 0)

{

  x = -x;

  f(x*2);

}

else 

{

  int i = 2;

  x *= i;

  f(x);

}

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

Условный оператор можно расширить для проверки нескольких условий:

if (x < 0)

  cout << "Отрицательная величина";

else if (x > 0)

  cout << "Положительная величина";

else

  cout << "Ноль";

Конструкций else if может быть несколько.

Допускается сокращенная  форма  условного  оператора,  в  которой отсутствует else и оператор_2.

if (x > 0)

  x = -x;

Оператор_1 и оператор_2 могут также быть условными. Каждое else соответствует ближайшему if.

2.2 Оператор выбора

Хотя любые комбинации условий можно выразить с помощью оператора if, довольно часто запись становится неудобной и запутанной. Оператор выбора switch используется, когда для каждого из нескольких возможных значений выражения нужно выполнить определенные действия.

Оператор switch предназначен для организации выбора из множества различных вариантов. Формат оператора следующий:

switch (переключающее_выражение)

{

  case константное_выражение_1: операторы_1;

  case константное_выражение_2: операторы_2;

  case константное_выражение_n: операторы_n;

  default:

      операторы;

}

Выражение, следующее за ключевым словом switch в круглых скобках, может быть любым выражением, допустимыми в языке СИ, значение которого должно быть целым.  Значение этого выражения является ключевым для выбора из нескольких вариантов. Тело оператора switch состоит из нескольких операторов, помеченных ключевым словом case с последующим константным выражением.  Так как константное выражение вычисляется во время трансляции, оно не может содержать переменные или вызовы функций. Обычно в качестве константного выражения используются целые или символьные константы.

Все константные выражения в операторе switch должны быть уникальны. Кроме операторов, помеченных ключевым словом case, может быть, но обязательно один, фрагмент, помеченный ключевым словом default.

Список операторов может быть пустым, либо содержать один или более операторов. Причем в операторе switch не требуется заключать последовательность операторов в фигурные скобки.

Управление передается тому из помеченных с помощью case операторов, для которых значение константного  выражения  совпадает  со значением переключающего выражения.

С помощью break осуществляется выход из переключателя. В переключателе могут находиться описания и определения объектов, т.е. составной оператор, входящий в переключатель, может быть блоком.

#include<iostream.h>

void main()

{

  int ic;

  cout <<"\n Введите любую десятичную цифру:";

  cin >> ic;

  cout << '\n';

  switch (ic)

  {

      case 0: cout << "ноль"; break;

      case 1: cout << "один,"; break;

      case 2: cout << "два "; break;

      case 3: cout << "три,"; break;

      case 4: cout << "четыре"; break;

      case 5: cout << "пять,"; break;

      case 6: case 7: cout << "шесть или семь,"; break;

      case 8: case 9: cout << "восемь или девять."; break;

      default: cout << "ОШИБКА!":

  }

}

2.3 Отношения и логические выражения

Отношение определяется как пара арифметических выражений, соединенных (разделенных) знаком операции отношения. Знаки операций отношения

!=   не равно;

==  равно;

<    меньше;

>    больше;

<=   меньше или равно;

>=   больше или равно;

Логический тип в языке Си отсутствует, поэтому принято, что отношение имеет ненулевое значение (обычно 1), если оно истинно, и равно 0, если оно ложно. Таким образом, значением отношения 6 <= 44 будет 1.

Операции >, >=, <, <= имеют один ранг

Операции сравнения на равенство == и != также имеют одинаковый, но более низкий ранг

Арифметические операции имеют более высокий ранг, чем операции отношений, поэтому в первом примере для выражения а-b не нужны скобки.

Логических операций в языке Си три: !   —   отрицание, т.е. логическое НЕ;  && –  конъюнкция, т.е. логическое И; ||  –  дизъюнкция, т.е. логическое ИЛИ.

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

3 Контрольные вопросы

  1.  Опишите оператор выбора case.
  2.  Опишите условный оператор if.
  3.  Какое назначение оператора break.
  4.  Какие операции отношения вы знеаете
  5.  Каков приоритет логических выражений.

4 Задание

  1.  Написать программу в соответствии с вариантом задания из пункта 5.
  2.  Проверить работоспособность программы.
  3.  Отладить и протестировать программу.
  4.  Оформить отчёт.

5 Варианты заданий

5.1 Оператор if

1) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

2) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

3) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

4) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

5) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

6) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

7) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

8) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

10) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

11) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

12) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

13) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

14) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

15) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

16) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

17) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

18) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

19) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

20) Вычислить и вывести на экран значения функции F.

где а, Ь, с — действительные числа.

Значения а, b, с, x  ввести с клавиатуры.

5.2 Оператор switch

1. Представить заданное целое число от 1 до 10 в римской системе счисления.

2. Реализовать в программе меню выбора арифметических действий. В зависимости от варианта посчитать значение выражения Y:=X{+|-|*|/}А. Х и А вводятся.

3. Написать программу, которая требует ввода числа месяца и, в зависимости от введенного значения, сообщает номер декады.

4. Написать программу, где ожидается ввод символа с клавиатуры, после чего определяется, является ли этот символ буквой, цифрой или специальным символом.

5. Написать программу, которая ждет ввода первой буквы названия месяца. В зависимости от этого определяет квартал. Учесть: Июнь, Июль – разные кварталы.

6. Написать программу, которая ждет ввода буквы русского алфавита и в зависимости от этого определяет гласная или согласная. Если согласная, то звонкая или глухая.

7. Написать программу, которая ждет ввода первой буквы названия месяца. В зависимости от этого определяет время года.

8. Написать программу, которая требует ввода времени дня и, в зависимости от введенного значения, желает доброго утра, доброго дня, доброго вечера или спокойной ночи.

9. Написать программу, которая ждет ввода буквы и, в зависимости от введенного значения, сообщает, является ли буква заглавной или строчной.

10. Написать программу, которая запрашивает ваше имя и рост в сантиметрах, а затем отображает информацию в виде: высокий, средний, низкий.

6 Содержание отчета

  1.  Титульный лист.
  2.  Наименование и цель работы.
  3.  Краткое теоретическое описание.
  4.  Задание на лабораторную работу.
  5.  Схема  алгоритма.
  6.  Листинг программы.
  7.  Результаты выполнения программы.


 

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

31796. Методы моделирования знаний при принятии управленческого решения 34.5 KB
  Методы моделирования знаний при принятии управленческого решения. Проблема моделирования знаний решается в разделе информатики который носит название Искусственный интеллект. Основой любой системы искусственного интеллекта является модель знаний и созданная на ее основе база знаний. Всякая конкретная база знаний содержит модель определенной предметной области.
31797. Место принятия решений в цикле управления. Сущность и классификация управленческих решений 37 KB
  Сущность и классификация управленческих решений. Одной из важнейших задач теории принятия решений ТПР явл достижение большей убедительности выводов и рекомендаций ЛПР и обоснованности выбора лучшего решения. Предметом РУР: не ответ на какое решение принять в той или иной ситуации а ответ на как организовать процесс разработки и принятия решений какие методы при этом использовать.
31798. Концепции и принципы принятия управленческих решений 34.5 KB
  Методология ТПР базируется на совокупности концепции принципов ТПР Концепции Принципы Системы Цели Рацть Множть альтер Наилучш реш Измерение Система необходимо рассм организационную среду как систему Рациональности принятие решения наилучшего варианта среди др принято считать логически не противоречивую полную и количественно подтвержденную систему докв. Наилучшего решения необходимо выбрать...
31799. Модель проблемной ситуации и принятие решений 30 KB
  situtio положение 1 соотношение обстоятельств и условий в крых разворачивается деятельность человека или группы содержащее противоречие и не имеющее однозначного решения; 2 психол. Начальным звеном разрешения возникшего противоречия является заданный человеком самому себе вопрос о причинах возникшей трудности. Проблемная ситуация предполагает неудовлетворенность лица принимающего решения целеустремленное состояние и необходимость действий для устранения проблемы. Свва проблем: 1ее нужно решать 2неповторимость ситуации выбора...
31800. Характеристика процесса разработки решений в сложных ситуациях 31.5 KB
  Характеристика процесса разработки решений в сложных ситуациях. В состав второго блока этапов разработки управленческого решения входят: генерирование альтернативных вариантов решений; отбор основных вариантов управленческих воздействий; разработка сценариев развития ситуации; экспертная оценка основных вариантов управляющих воздействий. Разработка решений это не есть однократный волевой акт осуществляемый ЛПР. Под сложными ситуациями разработки решений мы понимаем такие проблемные ситуации которые отличаются от несложных обыденных...
31801. Методы и технологии разработки управленческих решений в условиях определенности 30 KB
  2 Лексикографическая задача 3 Метод последовательных уступок Суть метода последовательных уступок Процедура решения многокритериальной задачи методом последовательных уступок заключается в том что все частные критерии располагают и нумеруют в порядке их относительной важности; максимизируют первый наиболее важный критерий; затем назначают величину допустимого снижения значения этого критерия и максимизируют второй по важности частный критерий при условии что значение первого критерия не должно отличаться от максимального более чем на...
31802. Понятие риска, составляющие и источники рисков в управлении 26 KB
  Понятие риска составляющие и источники рисков в управлении. Риск [греч. Риск предполагает неуверенность либо невозможность получения достоверного знания о благоприятном исходе в заданных внешних обстоятельствах; Риск в узком смысле измеряемая или рассчитываемая вероятность неблагоприятного исхода что подразумевает наличие статистических данных. Риск принято рассматривать как историческую и экономическую категории.
31803. Стратегии управления риском 24.5 KB
  При принятии страт решений необходимо проводить анализ рисков: 1Качественный анализ определение факторов риска и обстоятельств приводящих к рискованным ситуациям. 2Количественный анализ позволяет вычислить величину отдельных рисков и риска проекта в целом. Способы измерения риска: 1Стаитстическая оценка 2Экспертаная 3Оценка на основе моделей принятия решений.избежание риска.
31804. Технология принятия решений в условиях стохастического риска 24 KB
  Изменение величины риска или степени риска: Среднее ожидаемое значение. Среднее значение: 1Средневзвешенное для всех возможных резв где вероятность каждого реза используется в качестве частоты или вес соотвго значения. 2Дисперсия представляет собой среднее взвешенное из квадратов отклонений действующих результатов от средних ожиданий 3Среднее ожидаемое значение отклонений прибыли от ее средне ожидаемых значений или среднеквадратическое отклонение рассчитывается по формуле.