|
Лабораторные работы №3-7. Лабораторная работа программирование алгоритмов линейной структуры на языке c#
ЛАБОРАТОРНАЯ РАБОТА № 4. ПРОГРАММИРОВАНИЕ АЛГОРИТМОВ РАЗВЕТВЛЯЮЩЕЙСЯ СТРУКТУРЫ НА ЯЗЫКЕ C#
Цель работы: овладение практическими навыками разработки и программирования вычислительного процесса разветвляющейся структуры на языке С#, получить опыт работы с условными операторами языка С#. Теоретическая часть На практике решение большинства задач не удается описать с помощью программ линейной структуры. При этом после проверки некоторого условия выполняется та или иная последовательность операторов, однако происходит нарушение естественного порядка выполнения операторов.
Операторы ветвления позволяют изменить порядок выполнения операторов в программе. К операторам ветвления относятся условный оператор if и оператор выбора switch.
Оператор if обеспечивает передачу управления на одну из двух ветвей вычислений, а оператор switch — на одну из произвольного числа ветвей.
Условный оператор if может иметь одну из форм: сокращенную или полную.
Форма сокращенного оператора if: if (B) S;
где В - логическое или арифметическое выражение, истинность которого проверяется; S - оператор: простой или составной.
При выполнении сокращенной формы оператора if сначала вычисляется выражение B, затем проводится анализ его результата: если B истинно, то выполняется оператор S; если B ложно, то оператор S пропускается. Таким образом, с помощью сокращенной формы оператора if можно либо выполнить оператор S, либо пропустить его.
Форма полного оператора if:
if (B) S1; else S2;
где B - логическое или арифметическое выражение, истинность которого проверяется; S1, S2- оператор: простой или составной.
При выполнении полной формы оператора if сначала вычисляется выражение B, затем анализируется его результат: если B истинно, то выполняется оператор S1, а оператор S2 пропускается; если B ложно, то выполняется оператор S2, а S1 - пропускается. Таким образом, с помощью полной формы оператора if можно выбрать одно из двух альтернативных действий процесса обработки данных.
Рассмотрим несколько примеров записи условного оператора if:
if (a > 0) x=y; // Сокращенная форма c простым оператором
if (++i) {x=y; y=2*z;} // Сокращенная форма c составным оператором
if (a > 0 || b<0) x=y; else x=z; // Полная форма с простым оператором
if (i+j-1) { x= 0; y= 1;} else {x=1; y:=0;} // Полная форма с составными операторами Пример использования условного оператора.
static void Main()
{
Console.Write("x= ");
float x = float.Parse(Console.ReadLine());
Console.Write("y=");
float y = float.Parse(Console.ReadLine());
if (x < y ) Console.WriteLine("min= "+x);
else Console.WriteLine("min= "+y);
}
Результат работы программы:
x y min
0 0 0
1 -1 -1
-2 2 -2
Операторы S1 и S2 могут также являться операторами if. Такие операторы называют вложенными. При этом ключевое слово else связывается с ближайшим предыдущим словом if, которое еще не связано ни с одним else.
Оператор switch (переключатель) предназначен для разветвления процесса вычислений на несколько направлений. Формат оператора:
switch ( <выражение> )
{
case <константное_выражение_1>: [<оператор 1>]; <оператор перехода>;
case <константное_выражение_2>: [<оператор 2>]; <оператор перехода>;
...
case <константное_выражение_n>: [<оператор n>]; <оператор перехода>;
[default: <оператор>; ]
}
Выражение, записанное в квадратных скобках, является необязательным элементом в операторе switch. Если оно отсутствует, то может отсутствовать и оператор перехода.
Выражение, стоящее за ключевым словом switch, должно иметь арифметический, символьный, строковый тип или тип указатель. Все константные выражения должны иметь разные значения, но их тип должен совпадать с типом выражения, стоящим после switch или приводиться к нему. Ключевое слово case и расположенное после него константное выражение называют также меткой case.
Выполнение оператора начинается с вычисления выражения, расположенного за ключевым словом switch. Полученный результат сравнивается с меткой case. Если результат выражения соответствует метке case, то выполняется оператор, стоящий после этой метки, за которым обязательно должен следовать оператор перехода: break, goto и т.д. При использовании оператора break происходит выход из switch и управление передается оператору, следующему за switch. Если же используется оператор goto, то управление передается оператору, помеченному меткой, стоящей после goto.
Если совпадения не произошло, выполняются операторы, расположенные после слова default (при его отсутствии управление передается следующему за switch оператору).
Если необходимо, чтобы для разных меток выполнялось одно и тоже действие, то метки перечисляются через двоеточие.
Пример:
switch (oper)
{
case '+': res = a + b; break;
case '-': res = a - b; break;
case '*': res = a * b; break;
case '/': case ':': if (b != 0) // перечисление меток
{
res = (float)a / b; break;
}
else goto default;
default: ok = false; break;
} Операторы безусловного перехода
В С# есть несколько операторов, изменяющих естественный порядок выполнения команд: оператор безусловного перехода goto, оператор выхода break, оператор перехода к следующей итерации цикла continue, оператор возврата из метода return и оператор генерации исключения throw.
Оператор безусловного перехода goto Оператор безусловного перехода goto имеет формат:
goto <метка>;
В теле той же функции должна присутствовать ровно одна конструкция вида:
<метка>: <оператор>;
Оператор goto передает управление на помеченный меткой оператор. Рассмотрим пример использования оператора goto: static void Main()
{
float x;
metka: Console.WriteLine("x="); //оператор, отмеченный меткой
x = float.Parse(Console.ReadLine());
if (x!=0) Console.WriteLine("y({0})={1}", x, 1 / x );
else
{
Console.WriteLine("функция не определена");
goto metka; // передача управление метке
}
}
Следует учитывать, что использование оператора goto затрудняет чтение больших по объему программ, поэтому использовать метки нужно только в крайних случаях, например, в операторе switch.
Оператор выхода break Оператор break используется внутри операторов ветвления и цикла для обеспечения перехода в точку программы, находящуюся непосредственно за оператором, внутри которого находится break. Операции отношения (<, >,==, <, >, !=) являются бинарными, то есть имеют два операнда, и формируют результат типа bool, равный true или false.
Вопросы для самоконтроля
Какие условные операторы существуют в языке С#?
Для чего используется оператор if?
Как в операторе if проверить сразу несколько условий?
Как осуществляется выход из оператора switch?
Какого типа могут быть константные выражения, используемые в операторе switch?
Когда в операторе switch выполняется ветвь default?
Какие служебные слова используются при записи условного оператора?
Приведите пример составного оператора.
Как называются программы, в основе которых лежит структура следование?
Какой тип может иметь выражение, стоящее за ключевым словом switch?
Назначение ветви default оператора switch?
Назовите операторы перехода языка С#.
Каким образом будет выглядеть запись оператора switch, если необходимо, чтобы для разных меток выполнялось одно и тоже действие?
Практическая часть Задание №1. Написать программу, которая вычисляет значение функции у:
Задание №2. Написать программу, которая определяет:
максимальное значение для двух различных вещественных чисел.
является ли заданное целое число четным.
является ли заданное целое число нечетным.
если целое число М делится на целое число N, то на экран выводится частное от деления, в противном случае выводится сообщение "M на N нацело не делится".
оканчивается ли данное целое число цифрой 7.
имеет ли уравнение ax2+bx+c=0 решение, где a, b, c – данные вещественные числа.
какая из цифр четырехзначного числа больше: первая или вторая.
одинаковы ли цифры данного трехзначного числа
является ли сумма цифр двухзначного числа четной.
является ли сумма цифр трехзначного числа нечетной.
кратна ли трем сумма цифр двухзначного числа.
кратна ли числу А сумма цифр двухзначного числа.
какая из цифр трехзначного числа больше: первая или последняя.
какая из цифр трехзначного числа больше: первая или вторая.
какая из цифр трехзначного числа больше: вторая или последняя.
все ли цифры трехзначного числа одинаковые.
существует ли треугольник с длинами сторон a, b, c.
является ли треугольник с длинами сторон a, b, c прямоугольным.
является ли треугольник с длинами сторон a, b, c равнобедренным.
является ли треугольник с длинами сторон a, b, c равносторонним.
сумму второй и последней цифр четырехзначного числа А.
произведение первой и последней цифр четырехзначного числа А.
сумму первой, третьей и последней цифр пятизначного числа А.
произведение второй и четвертой цифр пятизначного числа А.
кратна ли числу А сумма цифр семизначного числа.
Задание №3. Дана точка на плоскости с координатами (х, у). Составить программу, которая выдает одно из сообщений "Да", "Нет", "На границе" в зависимости от того, лежит ли точка внутри заштрихованной области, вне заштрихованной области или на ее границе.
Области задаются графически следующим образом: 1.
| 2.
| 3.
| 4.
| 5.
| 6.
| 7.
| 8.
| 9.
| 10.
| 11.
| 12.
| 13.
| 14.
| 15.
| 16.
| 17.
| 18.
| 19.
| 20.
| 21.
| 22.
| 23.
| 24.
|
25.
|
|
|
|
Задание №4. Составить программу (при решении данных задач использовать оператор switch или вложенные операторы if):
Дан порядковый номер дня недели, вывести на экран его название.
Дан порядковый номер месяца, вывести на экран количество месяцев оставшихся до конца года.
Дан порядковый номер дня месяца, вывести на экран количество дней оставшихся до конца месяца.
Дан номер масти m (), определить название масти. Масти нумеруются: "пики" - 1, "трефы" - 2, "бубны" - 3, "червы" - 4.
Дан номер карты k (), определить достоинство карты. Достоинства определяются по следующему правилу: "туз" - 14, "король" - 13, "дама" - 12, "валет" - 11, "десятка" - 10, …, "шестерка" - 6.
Дан номер масти m () и номер достоинства карты k (). Определить полное название соответствующей карты в виде "дама пик", "шестерка бубен" и т.д.
С 1 января 2000 года по некоторый день прошло n дней, определить название текущего месяца.
С 1 января 2000 года по некоторый день прошло m месяцев, определить название текущего месяца.
С некоторой даты по настоящий день прошло m месяцев, определить название месяца неизвестной даты.
С некоторой даты по настоящий день прошло m месяцев, найти неизвестную дату.
С некоторой даты по настоящий день прошло n дней, найти неизвестную дату.
С 1 января 2000 года по некоторый день прошло m месяцев и n дней, определить название текущего месяца.
Дано расписание приемных часов врача. Вывести на экран приемные часы врача в заданный день недели (расписание придумать самостоятельно).
Проведен тест, оцениваемый в целочисленный баллах от нуля до ста. Вывести на экран оценку тестируемого в зависимости от набранного количества баллов: от 90 до 100 - "отлично", от 70 до 89 - "хорошо", от 50 до 69 - "удовлетворительно", менее 50 - "неудовлетворительно".
Дан год. Вывести на экран название животного, символизирующего заданный год по восточному календарю.
Дан возраст человека мужского пола в годах. Вывести на экран возрастную категорию: до года - "младенец", от года до 11 лет - "ребенок", от 12 до 15 лет - "подросток", от 16 до 25 лет - "юноша", от 26 до 70 лет - "мужчина", более c лет - "старик".
Дан пол человека: м - мужчина, ж - женщина. Вывести на экран возможные мужские и женские имена в зависимости от введенного пола.
Дан признак транспортного средства: a - автомобиль, в - велосипед, м - мотоцикл, с - самолет, п - поезд. Вывести на экран максимальную скорость транспортного средства в зависимости от введенного признака.
Дан номер телевизионного канала. Вывести на экран наиболее популярные программы заданного канала.
Дан признак геометрической фигуры на плоскости: к - круг, п - прямоугольник, т - треугольник. Вывести на экран периметр и площадь заданной фигуры (данные, необходимые для расчетов, запросить у пользователя).
Известны год и номер месяца рождения человека, а также год и номер месяца сегодняшнего дня (январь – 1 и т.д.). Определите возраст человека (число полных лет). В случае совпадения указанных номеров месяцев считать, что прошел полный год.
Работа светофора для пешеходов запрограммирована следующим образом: начиная с начала каждого часа, в течение трех минут горит зеленый сигнал, затем в течение двух минут – красный, в течение трех минут – опять зеленый и т.д. Дано вещественное число п, означающее время в минутах, прошедшее с начала очередного часа. Определить, сигнал какого цвета горит для пешеходов в этот момент.
Дано целое число п (). Определить, каким днем недели (понедельником, вторником, …, воскресеньем) является п-й день невисокосного года, в котором 1 января является понедельником.
Дата некоторого дня характеризуется 3 натуральными числами: k (год), m (порядковый номер месяца) и n (число). По заданным k, m и n определить дату предыдущего дня, считая, что заданный год не является високосным.
Дата некоторого дня характеризуется 3 натуральными числами: k (год), m (порядковый номер месяца) и n (число). По заданным k, m и n определить дату следующего дня, считая, что заданный год может быть високосным.
Задание №5. Составить программу решения задачи:
Используя сведения о результатах сдачи n вступительных экзаменов m абитуриентами, определить, сколько абитуриентов сдали все экзамены на "отлично".
Малое предприятие в первый день работы выпустило P единиц товарной продукции. Каждый последующий день оно выпускало продукции на Q единиц больше, чем в предыдущий. Сколько дней потребуется предприятию, чтобы общее количество выпущенной продукции за все время работы впервые превысило запланированный объем?
Определить, имеется ли среди заданных целых чисел A, B, C хотя бы одно чётное.
Найти наибольшее из трёх заданных чисел.
Найти наименьший делитель заданного натурального числа A (не считая единицы).
Определить, является ли заданное натуральное число палиндромом (палиндром – число, одинаково читаемое слева направо и справа налево).
Даны сведения о количестве забитых голов каждого футболиста команды в каждом из матчей чемпионата. Проверить, сколько в команде есть футболистов, забивших хотя бы два гола.
В баскетбольную команду могут быть приняты ученики, рост которых превышает 170 см. Составьте список кандидатов в команду из учеников класса.
Даны три числа. Выбрать те из них, которые принадлежат заданному отрезку [e, f].
Значения заданных переменных a, b и c перераспределить таким образом, что a, b, c станут, соответственно, наименьшим, средним и наибольшим значениями.
В соревнованиях по фигурному катанию N судей независимо выставляют оценки спортсмену. Затем из объявленных оценок удаляют самую высокую (одну, если самую высокую оценку выставили несколько судей). Аналогично поступают с самой низкой оценкой. Для оставшихся оценок вычисляется среднее арифметическое, которое и становится зачетной оценкой. По заданным оценкам судей определить зачетную оценку спортсмена.
Определить по данным музейного каталога, есть ли в музее хотя бы одна картина Левитана или Шишкина. Если есть, выдать ее название, в противном случае выдать соответствующий текст.
Даны сведения о количестве забитых голов каждого футболиста команды в каждом из матчей чемпионата. Проверить, сколько в команде есть футболистов, забивавших голы в каждом матче.
Ввести с клавиатуры a и b. Найти сумму целых чисел, принадлежащих отрезку [a, b].
Определить по прейскуранту, можно ли подобрать в спортивном магазине велосипед, стоимость которого не превышает имеющуюся у покупателя сумму.
Даны сведения о количестве забитых голов каждого футболиста команды в каждом из матчей чемпионата. Проверить, сколько в команде есть футболистов, не забивших ни одного гола.
Определить, есть ли среди цифр заданного целого трёхзначного числа одинаковые.
Известен начальный вклад клиента в банк и процент годового дохода. Определить, через сколько лет вклад превысит заданный размер и каков при этом будет размер вклада.
Используя сведения о ежемесячных выплатах зарплаты сотрудникам фирмы, выяснить, не оказалась ли годовая зарплата кого-либо из сотрудников ниже годового минимума, оговоренного в его контракте.
Составьте программу, которая проверяет, является ли заданное число совершенным. Совершенным называется натуральное число, равное сумме всех своих делителей (исключая само число). Например: 28=1+2+4+7+14.
Проверить, можно ли построить треугольник из отрезков с длинами x, y, z и, если можно, то какой – остроугольный, прямоугольный или тупоугольный.
Дано натуральное N. Выяснить, сколько цифр оно содержит.
Дано трехзначное число. Определить, равен ли квадрат этого числа сумме кубов его цифр?
Используя сведения о размере обуви каждого члена баскетбольной команды, а также сведения о наличии в обувном магазине размеров спортивной обуви, определить, сколько членов команды можно обуть в этом магазине.
Определите, равна ли сумма крайних цифр некоторого четырехзначного числа сумме его средних цифр.
Задание №6. Составить программу решения задачи:
В шеренге спортсмены стоят по росту. Определить по номеру спортсмена вид спорта, которым он занимается: 1, 2, 9 - баскетбол, 3, 4, 5 - бег, 6, 7, 8 - штанга.
Задать с помощью генератора случайных чисел номер ряда в кинотеатре - целое число от 1 до 25. Определить сколько стоит билет, если его цена зависит от ряда: 1,2,3, 25- 10 руб, 4,5 - 15 руб, с 6 по 24 - 20 рублей.
В поезде 17 вагонов. С 10 по 17 вагоны купейные, а остальные - плацкартные. Ввести с клавиатуры номер вагона. Напечатать его вид.
Один мальчик на перемене 12 раз дергал девочек за косички. Ввести номер косички. Определить, кому она принадлежит: 1, 2, 3, 8 - девочке из 3"а", 4, 5, 6 - девочке из 3"б", 7, 10, 11, 12 - девочке из 3"в", 9 - завучу Маргарите Багратионовне.
В поликлинике кабинеты распределены так: 1, 2, 3, 17 - окулисты, 4, 18, 19, 20 - хирурги, 5-8 стоматологи, 9-16 - педиатры. Задать целое число от 1 до 20 (номер кабинета) и определить специальность врача.
Вовочка, любитель стрелять из рогатки, 7 раз попадал в милицию. Ввести случайным образом число - номер попадания. Определить результат: 4, 6, 7 - милиционеры вставляли новое стекло, 1, 2, 3, 5 - майор лично менял разбитые лампочки.
Во время сильного дождя на остановке стояло 12 человек. Подкативший автобус забрызгал грязью 4-го, 5-го, 6, 7 и 8-го человека. Остальные попрыгали в колючие кусты, причем 3-ий, 9-ый и 12-ый так и не смогли выбраться из них. Задать номер пассажира и определить грязный он или исцарапанный.
Во время сильного дождя на остановке стояло 12 человек. Подкативший автобус забрызгал грязью 4-го, 5-го, 6, 7 и 8-го человека. Остальные попрыгали в колючие кусты, причем 3-ий, 9-ый и 12-ый так и не смогли выбраться из них. Задать номер пассажира и определить едет или сидит в кустах.
С автостанции автобусы отправляются по 16 маршрутам и переезжают через реку по 4-м мостам: 1, 2, 3, 5 - по Южному, 4, 6, 7, 8 - по Центральному, 9, 10, 11, 12 - по Северному, 13, 14, 15, 16 - по Окружному. Ввести с клавиатуры номер маршрута. Определить, по какому мосту он пойдет.
На мини-рынке продают молоко и цветы. Задать случайным образом N - номер торгового места - целое число от 1 до 6. Определить, чем торгуют: 1, 3, 5 - молоко, 2, 4, 6 - цветы.
По дате (месяц и день) рождения определите знак Зодиака.
Составьте программу вычисления по заданному радиусу и значению переменной k площади круга (если k=1), длины окружности (если k=2) или объема шара (если k=3).
Напечатайте календарь заданного месяца 1998 года, зная, что 1 января 1998 года – четверг.
Для значений целого числа k от 1 до 99 напечатайте фразу «мне k лет», учитывая при этом, что при некоторых значениях k слово «лет» надо заменить словом «год» или «года».
Для натурального числа k напечатайте фразу «мы нашли k грибов в лесу», согласовав окончание слова «гриб» с числом k.
В старояпонском календаре был принят 60-летний цикл, состоявший из пяти 12-летних-подциклов. Подциклы обозначались названиями цвета: зеленый, красный, желтый, белый, черный. Внутри каждого подцикла года носили названия животных; крысы, коровы, тигра, зайца, дракона, змеи, лошади, овцы, обезьяны, курицы, собаки и свиньи (1984 год - год зеленой крысы - был началом очередного цикла). Напишите программу для ввода номера некоторого года нашей эры и вывода его названия по старояпонскому календарю.
Пусть на шахматной доске заданы два поля: р1 и р2. Определите, какая из шахматных фигур при установке на поле р1 бьет фигуру, стоящую на поле р2. Координаты на шахматной доске определяются по горизонтали от а до h и по вертикали от 1 до 8. Белые фигуры двигаются от 8-й горизонтали к 1-й, а черные - от 1-й к 8-й.
Пусть (k, l), (m, n) - поля шахматной доски: k, m - номера по горизонтали; l, n - номера по вертикали (ll) попасть на поле (m, n) одним ходом пешки.
Пусть (k, l), (m, n) - поля шахматной доски: k, m - номера по горизонтали; l, n - номера по вертикали (ll) попасть на поле (m, n) одним ходом ладьи.
Пусть (k, l), (m, n) - поля шахматной доски: k, m - номера по горизонтали; l, n - номера по вертикали (ll) попасть на поле (m, n) одним ходом слона.
Пусть (k, l), (m, n) - поля шахматной доски: k, m - номера по горизонтали; l, n - номера по вертикали (ll) попасть на поле (m, n) одним ходом ферзя.
Пусть даны вещественные положительные числа а, b, с, d. Выясните, можно ли прямоугольник со сторонами а, b разместить внутри прямоугольника со сторонами с, d так, чтобы каждая из сторон одного прямоугольника была параллельна или перпендикулярна каждой стороне второго прямоугольника.
Введите три числа. Если они могут быть длинами сторон прямоугольного треугольника, выведите их в порядке возрастания и вычислите площадь полученного треугольника.
Введите три числа. Если они могут быть сторонами равностороннего треугольника, вычислите его площадь и длину высоты. Выведите длины сторон треугольника, площадь и длину высоты в порядке возрастания.
Пусть даны координаты вершин четырехугольника. Составьте программу, которая определяла бы, является ли этот четырехугольник прямоугольником.
Задание №7. Составить программу решения задачи:
Из трехзначного числа х вычли его последнюю цифру. Когда результат разделили на 10, а к частному слева приписали последнюю цифру числа х, то получилось число 237. Найти число х.
Из трехзначного числа х вычли его последнюю цифру. Когда результат разделили на 10, а к частному слева приписали последнюю цифру числа х, то получилось число n. Найти число n. По изданному n найти число х (значение n вводится с клавиатуры, и при этом число десятков в n не равно нулю).
В трехзначном числе х зачеркнули первую цифру. Когда оставшееся число умножили на 10, а произведение сложили с первой цифрой числа х, то получилось число 564. Найти число х.
В трехзначном числе х зачеркнули первую цифру. Когда полученное число умножили на 10, а произведение сложили с первой цифрой числа х, то получилось число n. По заданному n найти число х (значение n вводится с клавиатуры, ).
В трехзначном числе х зачеркнули его вторую цифру. Когда к образованному при этом двузначному числу слева приписали вторую цифру числа х, то получилось число546. Найти число х.
В трехзначном числе х зачеркнули его вторую цифру. Когда к образованному при этом двузначному числу слева приписали вторую цифру числа х, то получилось число n. По заданному n найти число n (значение n вводится с клавиатуры, и при этом число десятков в n не равно нулю).
В трехзначном числе х зачеркнули его вторую цифру. Когда к образованному при этом двузначному числу справа приписали вторую цифру числа х, то получилось число 456. Найти число х.
В трехзначном числе х зачеркнули его вторую цифру. Когда к образованному при этом двузначному числу справа приписали вторую цифру числа х, то получилось число n. По заданному n найти число х (значение n вводится с клавиатуры, ).
В трехзначном числе х зачеркнули его последнюю цифру. Когда в оставшимся двузначном числе переставили цифры, а затем приписали к ним слева последнюю цифру числа х, то получилось число 654. Найти число х.
В трехзначном числе х зачеркнули его последнюю цифру. Когда в оставшимся двузначном числе переставили цифры, а затем приписали к ним слева последнюю цифру числа х, то получилось число n. По заданному n найти число х (значение n вводится с клавиатуры, и при этом число единиц в n не равно нулю).
Даны цифры двух целых чисел: двузначного а2а1 и однозначного b, где а1 – число единиц, а2 – число десятков. Получить цифры числа, равного сумме заданных чисел (известно, что это число двузначное). Слагаемое – двузначное число и число-результат не определить; условный оператор не использовать.
Даны цифры двух двузначных чисел, записываемых в виде а2а1 и b2b1, где а1 и b1 – число единиц, а2 и b2 – число десятков. Получить цифры числа, равного сумме заданных чисел (известно, что это число двузначное). Слагаемое – двузначное число и число-результат не определять; условный оператор не использовать.
Даны цифры двух десятинных целых чисел: трехзначного а3а2а1 и b2b1, где а1 и b1 – число единиц, а2 и b2 – число десятков, а3 – число сотен. Подучить цифры числа, равного сумме заданных чисел (известно, что это число трехзначное). Числа-слагаемые и число-результат не определять, условный оператор не использовать.
Даны целое число k () и последовательность цифр 10111213…9899, в которой выписаны подряд все двузначные числа. Определить номер пары цифр, в которую входит k-я цифра.
Даны целое число k () и последовательность цифр 10111213…9899, в которой выписаны подряд все двузначные числа. Определить двузначное число, образованное парой цифр, в которую входит k-я цифра.
Даны целое число k () и последовательность цифр 10111213…9899, в которой выписаны подряд все двузначные числа. Определитьk-ю цифру, если известно, что k – четное число.
Даны целое число k () и последовательность цифр 10111213…9899, в которой выписаны подряд все двузначные числа. Определитьk-ю цифру, если известно, что k – нечетное число.
Даны целое число k () и последовательность цифр 10110203…149159, в которой выписаны подряд все трехзначные числа от 101 до 150. Определитьk-ю цифру, если известно, что k – число, кратное трем.
Даны целое число k () и последовательность цифр 10110203…149159, в которой выписаны подряд все трехзначные числа от 101 до 150. Определитьk-ю цифру, если известно, что k – одно из чисел 1, 4, 7, …
Даны целое число k () и последовательность цифр 10110203…149159, в которой выписаны подряд все трехзначные числа от 101 до 150. Определитьk-ю цифру, если известно, что k – одно из чисел 2, 5, 8, …
Даны целые числа h, m, s (, , ), указывающие момент времени: «h часов, m минут, s секунд». Определить угол (в градусах) между положением часовой стрелки в начале суток и в указанный момент времени.
С начала суток часовая стрелка повернулась на у градусов ( - вещественное число). Определить число полных часов и число полных минут, прошедших с начала суток.
Пусть даны целые числа h, m (,), указывающие момент времени: «h часов, m минут». Определить наименьшее время (число полных минут), которое должно пройти до того момента, тогда часовая и минутная стрелки на циферблате совпадут.
Пусть даны целые числа h, m (,), указывающие момент времени: «h часов, m минут». Определить наименьшее время (число полных минут), которое должно пройти до того момента, тогда часовая и минутная стрелки на циферблате расположатся перпендикулярно друг другу.
Часовая стрелка образует угол с лучом, проходящим через центр и через точку, соответствующую 12 часам на циферблате ().Определить значение угла для минутной стрелки, а также количество полных часов и полных минут.
Контрольные вопросы
Какие существуют операторы передачи управления?
Что необходимо для выполнения ветви условного оператора более одного оператора?
Что такое «метка»?
Когда следует использовать оператор безусловного перехода?
Какова структура полного условного оператора?
Какие действия выполняет оператор перехода?
Как работает оператор switch?
Что общего у условного оператора и оператора switch?
В чем отличие условного оператора от оператора switch?
Может ли список констант в операторе case состоять из одной константы?
Как будет выполняться оператор switch, если ни одна из констант не равна текущему значению выражения case?
Когда следует использовать оператор перехода goto?
В каких случаях используется оператор break?
|
|
|