ПРАКТИЧЕСКАЯ ЧАСТЬ. Рассмотрим примеры программ с операторами циклов if, for и do – if.
Рассмотрим примеры программ с операторами циклов if, for и do – if. Пример 1. Написать программу вывода на экран пользователя целых положительных чисел с помощью оператора if. Начальное и последнее число должно задаваться пользователем с клавиатуры. Программный код решения примера
Рис. 3.1. Результат выполнения программы с вводом целых чисел В программе использована функция scanf_s(), принятая в MS Visual Studio. Применено инкрементирование переменных, принятое в языке С, а именно ++i или ++j означает, что переменные увеличиваются на единицу. При этом знаки «++» могут располагаться перед именем переменной или после. Отличие в том, что ++i – это значение переменной после увеличения, а i++ – сначала переменная имеет заданное значение, а потом происходит ее увеличение. Для переменных цикла обе формы равнозначны. Условием цикла является то, что пока переменная i меньше или равна переменной n (предполагается, что n больше начального значения i), то будут выполняться действия (печать и увеличение переменной j), заложенные в теле цикла. Расчет выражения, заключенного в круглые скобки оператора, предназначен для проверки нестрогого неравенства переменной i по отношению к переменной n. Если это неравенство выполняется, то в теле цикла происходят печать и увеличение (инкрементирование) переменных i, j. Задание 1 1. Предусмотрите ввод только отрицательных чисел. 2. Предусмотрите ввод только неотрицательных чисел. 3. Предусмотрите вывод чисел и их порядковые номера (т. е. в два столбца). 4. Предусмотрите вывод чисел на консоль в виде строки. 5. Предусмотрите ввод и вывод только вещественных чисел. 6. С учетом предыдущего пункта предусмотрите вывод чисел и их порядковые номера (т. е. в два столбца). 7. Рассмотрите варианты форм инкрементирования. Выполните вывод на консоль. Пример 2. Написать программу посимвольного ввода предложения «Hello, world» и подсчитать число символов в нем (включая запятую и пробел). Программный код решения примера
В программе ввод символьных данных должен завершиться комбинацией клавиш Ctrl+Z, что будет соответствовать окончанию ввода (файла), т. е. EOF. Оператор цикла if будет выполняться до тех пор, пока не встретится так называемый конец файла EOF. В предложении \"Hello, world\"два обратных слэша включены для вывода на консоль двойных кавычек. Функции printf("\t") осуществляют табуляцию вводимых символов. Подсчет их числа выполняется с помощью переменной цикла (счетчика) i, которая инкрементируется в теле цикла. Заголовочный файл #include <conio.h> служит для поддержания консольного ввода-вывода для функции getch (). Без него при компиляции программы могут выводиться предупреждения, хотя программа с предупреждениями работает. Результат выполнения программы показан на рис. 3.2.
Задание 2 1. Введите комментарии с помощью символов // и /* ¼ */. 2. В качестве вводимых символов используйте буквы своей фамилии (латиницу). В отчет вставьте полученный результат. 3. В качестве вводимых символов используйте свои фамилию и имя. В отчет вставьте полученный результат. 4. Осуществите вывод своей фамилии и имени по главной диагонали дисплея. 5. В качестве символов введите числа от 1 до (2 + Х), где Х – номер компьютера, на котором выполняется лабораторная работа. В отчет вставьте полученный результат. 6. Выполните дублирование символов с помощью функции putchar(), которая отображает символы на экране пользователя. Примечание. Прототип функции putchar() имеет следующий вид: #include <stdio.h> int putchar (int ch); Пример 3. Написать программу табличного вывода строчных букв латинского алфавита и их десятичных кодов с помощью оператора цикла for. Как известно, в латинском алфавите 26 букв. Поэтому можно создать массив символов этих букв. С учетом того, что char представляет собой целочисленный тип, то можно обойтись без создания массива. Программный код решения примера
Рис. 3.3. Таблица десятичных кодов букв латинского алфавита Форматированный вывод данных предусматривает выравнивание по правому краю, для чего предусматриваются числовые спецификаторы типа %4d и %2c для целых чисел и символов в функции printf(). Задание 3 1. Примените префиксную форму инкрементирования переменной j. 2. Инкрементирование переменной j создайте отдельно в теле цикла. 3. Инициализацию переменной j начните с нуля. Результат выполнения программы должен быть тот же самый, что и в приведенной программе. 4. Напишите программу для вывода кодов букв из заданного диапазона на усмотрение пользователя, например от ' j ' до ' w '. 5. В цикле for заполните все поля. 6. Напишите программу для вывода кодов букв латинского алфавита прописных и строчных букв в одной таблице. 7. Выведите буквы своей фамилии и коды этих букв. Пример 4. Написать программу расчета значений функции распределения интервалов времени в потоке Эрланга 4-го порядка (k = 4) с параметром l = 2.3 на отрезке времени от 0 до 5 (условных единиц) с шагом 0.2: Программный код решения примера
В программе использованы вложенные циклы for. Применены специфические условия изменения переменных: t += 0.2; /* t = t + 0.2; */ f *= j; /* f = f * j; */ Lt *= (L*t); /* Lt = Lt * (L*t); */ Вычисление факториала выполнено с помощью произведения и выделения отдельного слагаемого суммы, когда рассчитывается 0!. В программе также предусмотрено накопление суммы для каждого шага времени t. Для расчета экспоненты в заголовок программы включена библиотека математических функций #include <math.h>. Результат выполнения программы представлен на рис. 3.4. Эрланга 4-го порядка Задание 4 1. В заголовке внешнего цикла for добавьте первое поле и устраните третье поле. 2. Предусмотрите вывод количества значений рассчитанной функции распределения. 3. Предусмотрите ввод параметров программы, а именно: порядок потока Эрланга k, параметр l, конечную величину временного интервала, шаг по времени. Пример 5. Вычислить с точностью до «машинного нуля» значение суммы числового ряда: Программный код решения примера
В приведенной программе сумма вычисляется как значение переменной sum2. Ее предыдущее значение сохраняется в переменной sum1. Так как приближенное значение с добавлением неотрицательных слагаемых не уменьшается, условием продолжения цикла служит отношение sum1 < sum2 (поскольку растет знаменатель denom). Когда при добавлении очередного слагаемого значение суммы остается неизменным (за счет конечной разрядной сетки для представления вещественных чисел), нарушается условие sum1 < sum2 и цикл прекращается. Таким образом, конечность разрядной сетки представления вещественных чисел в компьютере определяет собой «машинный нуль». Результат выполнения программы показан на рис. 3.5. Рис. 3.5. Результат подсчета суммы бесконечного ряда Задание 5 1. Подсчитайте число итераций цикла для подсчета суммы ряда. 2. Напишите программу с нулевой инициализацией переменной k. 3. Напишите условие «загрубения» результата подсчета суммы ряда. 4. В программе примените тип float вместо типа double. Проанализируйте результат. 5. Вместо оператора цикла do – if примените иной оператор цикла. Пример 6. Произвести реверс цифр заданного целого числа, вводимого с клавиатуры пользователем. Задача заключается в том, чтобы, например, число 123 переписать как 321. Программный код решения примера
В программе применена операция арифметическая операция деления по модулю, которая имеет символ процента, т. е. «%». Любой остаток, получающийся в результате деления целых чисел, будет отброшен [2]. В шкале старшинства оператор деления по модулю имеет приоритет, равный приоритету операторов умножения и деления. Переменные, используемые в программе, объявлены как длинные числа, поэтому применен тип long int (или long). В некоторых компиляторах имеются отличия между типами int и long int в смысле максимально поддерживаемого значения числа. Рис. 3.6. Результат программы по реверсу числа Задание 6 1. Предусмотрите подсчет итераций заданного цикла. 2. Напишите программу по реверсу числа с оператором цикла if. Протестируйте обе программы, в том числе по вводу числа 0. 3. Определите максимальное число вида 123¼987¼, для которого еще можно применить тип long int. Пример 7. На основе только оператора цикла for написать программу по выводу «горки» заглавных букв, симметрично убывающих к букве, введенной пользователем. Также на основе оператора цикла for предусмотреть защиту от неправильного ввода. Возможный программный код решения примера
Пример выполнения программы показан на рис. 3.7. Задание 7 1. Напишите программу на основе только оператора цикла for по выводу перевернутой горки букв, а также «левой» и «правой» горки. 2. Напишите программу на основе только оператора цикла for по выводу «ромба» букв, относительно введенной буквы. 3. Напишите программу по выводу горки букв только на основе оператора цикла if.
Контрольные вопросы 1. Как организуются составные операторы циклов в языке С? 2. Как организуются вложенные циклы в языке С? 3. В каких случаях может произойти зацикливание при использовании оператора цикла с предусловием? 4. В каких случаях может произойти зацикливание при использовании оператора цикла с постусловием? 5. Сколько условий требуется для работы оператора цикла с параметром? 6. Чем отличаются префиксное и постфиксное инкрементирование и декрементирование? 7. Каково различие в операторах цикла между префиксным и постфиксным инкрементированием? 8. Сколько операторов отношения в языке С? Перечислите их. 9. Как реализуется взаимозаменяемость операторов цикла if и for? 10. В чем сходство и различие между циклами с предусловием и с постусловием?
|