
- •Базовые понятия информатики. Понятие «Информатика» и «Информация»
- •Информация
- •Информационные технологии
- •Понятие алгоритма. Свойства и классы алгоритмов. Формы представления алгоритмов
- •Понятие алгоритма. Базовые алгоритмические структуры
- •Представление данных в памяти персонального компьютера.
- •Принципы обработки программных кодов
- •Компиляторы
- •Интерпретатор
- •Язык с. История развития. Основные свойства языка
- •Отличительные особенности языкаC
- •Элементы языка c
- •Константы
- •Базовые типы данных
- •Директива #include
- •Использование void
- •Инструкция return
- •Описание переменных
- •Обработка данных. Операторы
- •Арифметические операторы
- •Приоритет операторов и порядок вычислений
- •Используемые алгоритмы обработки данных
- •Аккумуляторы
- •Преобразования типов данных
- •Декларации и дефиниции функций
- •Формальные и фактические параметры. Вызов функций
- •Возврат функцией значений
- •Переменные в функциях
- •Автоматические (локальные) переменные
- •Внешние (глобальные) переменные
- •Статические переменные
- •Передача параметров по значению
- •Передача параметров по ссылке
- •Значения параметров по умолчанию
- •Перегрузка функций
- •Рекурсия
- •Встроенные функции
- •Обработка символьных данных
- •Функция puts()
- •Функция putchar()
- •Функция printf()
- •Выбор правильных средств вывода информации
- •Функция gets()
- •Функция getchar()
- •Функция scanf()
- •Выбор соответствующих средств ввода данных
- •Управляющие структуры Структуры выбора (if / else)
- •Структуры выбора (switch/case/default)
- •Структуры повторения (циклы)
- •Использование цикла for
- •Использование цикла do...While (постусловие)
- •Использование цикла while (предусловие)
- •Операторы передачи управления Оператор безусловного перехода goto
- •Оператор break
- •Оператор continue
- •Препроцессор языка Си
- •Массивы Объявление переменной массива
- •Использование индексной переменной
- •Инициализация массива при объявлении
- •Передача массивов в функции
- •Использование констант при объявлении массивов
- •Символьные строки
- •Массивы строк
- •Алгоритмы сортировки массива
- •Поиск заданного элемента в массиве
- •Указатели
- •Объявление указателя
- •Указатели на массивы
- •Операции над указателями
- •Указатели на строку
- •Указатели на функцию
- •Функции, возвращающие указатель
- •Указатели на многомерные массивы
- •Массивы указателей
- •Динамическое распределение памяти
- •Структуры данных
- •Реализация одних структур на базе других
- •Очередь
- •Операции над очередями
- •Операции над стеками
- •Ссылочные реализации структур данных
- •Операции над списками
Структуры выбора (switch/case/default)
Если в программе следует учесть больше трех возможных вариантов, конструкция с вложенными инструкциями if...else может оказаться очень запутанной. В таких случаях в качестве альтернативы используется переключатель switch. Переключатель switch представляет собой структуру, построенную по принципу меню, и содержит все возможные варианты условий и инструкции, которые следует выполнить в каждом конкретном случае. Пример подобной конструкции приведен ниже.
main()
{
intanswer;
puts("Си это: \n");
puts("1. Язык, на котором
говорят на юге Франции\n");
puts("2. Язык, который используется только
для написания \
больших компьютерных программ\n");
puts("3. Компилирующий язык, легко
совместимый с любыми системами\n");
puts("4. Ничего из перечисленного\n");
puts("Введите номер ответа\n");
answer = getchar();
putchar('\n');
switch (answer)
{
case '1':
puts("К сожалению, Вы ошиблись, \
на юге Франции говорят на языке Паскаль\n");
break;
case '2':
puts("Вы ошибаетесь,
язык Си используют для написания программ\n");
puts("любых типов и размеров\n");
break;
case '3':
puts("Очень хорошо, Вы
дали правильный ответ\n");
puts("Си является
компилирующим языком и может использоваться\n");
puts("с
любыми компьютерными системами\n");
break;
case '4':
puts("К сожалению,
Вы ошибаетесь, правильный ответ - номер 3\n");
break;
default:
puts("Вы ввели символ,
не соответствующий \
ни одному из номеров ответа\n");
}
В круглых скобках после переключателя switch находится переменная типа int или char, следом расположен блок инструкций, заключенных в фигурные скобки, которые содержат ряд ветвей case. Каждая ветвь case выполняет инструкции, основываясь на возможном значении переменной. Это значение должно быть представлено в виде целого числа или символа, заключенного в одинарные кавычки, либо в виде имени целочисленной или символьной константы.
Ветвь case '1':, например, предписывает программе выполнить следующие ниже инструкции, если значение переменной переключателя switch соответствует символу '1'. Если значение переменной отличается от единицы, компилятор переходит к проверке условия второй ветви case.
В тех случаях, когда значение переменной удовлетворяет условию ветви case, выполняются инструкции, следующие за данным условием. Инструкция break в конце каждой ветви case передает управление в конец switch, так что, как только выполнены инструкции одной из ветвей case, остальные игнорируются и выполнение switch завершается.
Если значение переменной не удовлетворяет условиям ни одной из ветвей case, выполняется ветвь, помеченная инструкцией default. Это дает возможность учесть все возможные варианты ввода. После инструкции default нет необходимости ставить break, поскольку она всегда является последней в процедуре выполнения switch. Имеет смысл включать default даже тогда, когда вы полагаете, что учли все возможные условия и все возможные случаи ввода значений.
Если вы пропустите инструкцию break, компьютер выполнит все инструкции, помещенные в соответствующей ветви case, и далее, вплоть до первого встреченного в тексте break. Вы можете использовать эту особенность для выполнения определенного набора инструкций, при наличии нескольких равноценных вариантов ответа, например, так:
case 'Y':
case 'y': puts ("Вы ответили \"Да\"");
break;
case 'N':
case 'n': puts ("Вы ответили \"Нет\"");
break;