Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология Образование Политология Производство Психология Стандартизация Технологии |
Числа и числовые последовательности.
Задача 2.12 Распечатать числовую последовательность, которая задается по следующим правилам: 3p+1, если p нечётное число, р/2, если р чётное число. Например: Задача 2.13 Распечатать числовую последовательность, которая задается по следующим правилам: Задача 2.14 Для заданного натурального числа определить, образуют ли его цифры арифметическую прогрессию. Предполагается, что в числе не менее трёх цифр. Задача 2.15 В трехзначном числе зачеркнули старшую цифру. Когда полученное число умножили на 7, то получили исходное число. Найти это число. Задача 2.16 Получить все числа, не превышающие заданного числа N, которые делятся без остатка на все свои цифры. Задача 2.17 Задано натуральное число. Записать его в обратном порядке. Например, 12345 должно превратиться в 54321. Задача 2.18 Напечатать все натуральные четырехзначные числа, в десятичной записи которых нет одинаковых цифр, и разность двух натуральных двузначных чисел, составленных из двух последовательных первых цифр и двух последовательных последних цифр числа, равна сумме всех цифр числа. Задача 2.19 В электронных часах время показывается на табло в виде последовательности цифр, указывающих часы (от 0 до 23), минуты и секунды. Геометрические задачи. Задача 2.20 Выпуклый многоугольник задан последовательностью координат своих вершин в порядке обхода: (x1, y1), (x2, y2), (x3, y3), ..., (xn, yn). Вычислить площадь многоугольника. Задача 2.21 Задана точка с координатами (x, y) и треугольник с координатами вершин (x1, y1), (x2, y2), (x3, y3). Определить, лежит ли точка внутри или вне треугольника. Календарь. Задача 2.22 Написать программу, которая по заданной дате (числу d и месяцу m) определяет число дней, прошедших от начала года, если известно, что год - не високосный. Задача 2.23 Написать программу, которая по заданному числу дней, прошедших от начала года, определяет дату: число d и месяц m, если известно, что год - не високосный. Задача 2.24 В журнале метеостанции записаны ежедневные температуры воздуха в г. Смоленске. Определить самый холодный будний день октября 1997 г., если известно, что 1 октября 1997 г. - среда. (Будними считаются все дни недели, за исключением субботы и воскресенья.) Задача 2.25 Компьютерный вирус " Пятница, 13" может повредить информацию только в те дни, когда 13 число попадает на пятницу. Определить все месяцы 2000 года, в которых 13 число было пятницей. Учесть, что 2000 год - високосный и 1 января 2000 года - суббота. В качестве ответа распечатать номера месяцев. Решения задач Задача 1.1 Для решения этой задачи необходимо знать, что 1 мегабайт=1024 килобайт, поэтому 6 мегабайт=6x1024=6144 килобайт. Обозначим t - время звучания композиции в секундах, v - объём файла композиции в килобайтах, тогда: Задача 1.2 Рассмотрим, как ходят фигуры: ферзь бьёт те поля (с координатами x, y ), которые находятся с ним на одной вертикали (x=x1), на одной горизонтали (y=y1), или на любой из диагоналей (|x - x1| = (|y - y1|). Конь за один ход переходит на два поля по одной координате и на одно поле по другой координате, то есть поля, которые он бьёт, определяются по правилу: либо |x - x2| = 2 и |y - y2|=1, либо |x - x2| = 1 и |y - y2| = 2. При решении нужно учитывать, что фигуры не могут угрожать друг другу одновременно, и может быть ситуация, когда фигуры вообще не угрожают друг другу. Задача 1.3 При решении учтите, что число рыбок должно быть целым числом. Например, в аквариуме объёмом 20, 5 литров может жить 6 рыбок (а не 6, 83333...). Функция выделения целой части числа x в Паскале - trunc(x). Задача 1.4 При решении учтите, что если полторы курицы за полтора дня сносят полтора яйца, то одна курица за тот же срок (полтора дня) снесет одно яйцо. Например: 6 кур за 6 дней снесут 24 яйца. Задача 1.5 Для решения этой задачи можно разделить число нацело N на 3 и рассмотреть остаток от деления. Существует три варианта: если остаток 0, то сумма выплачивается трехкопеечными монетами; если остаток 1 (наименьшее такое число 10), то необходимо убрать 3 монеты по 3 копейки и добавить 2 монеты по 5 копеек; если остаток от деления 2, то необходимо убрать 1 трёхкопеечную монету и добавить 1 монету достоинством 5 копеек. В Паскале операция деления нацело - div, операция вычисления остатка при делении целых чисел - mod. Задача 1.10 При решении этой задачи необходимо воспользоваться тем условием, что a и b - числовые переменные, тогда поменять их местами можно, например, следующим образом: Задача 2.1 Разделим N нацело на 5 и получим k - максимальное значение для y (т.е. 0< =y< =k). Организуем цикл по переменной y, и будем рассматривать значения разности N-5y. Если это число делится нацело на 3, то полученное частное и есть соответствующее значение x. Задача 2.3 Для решения этой задачи необходимо вычислять функцию n! (читается n - факториал), которая представляет собой произведение натуральных чисел от 1 до n. Программа вычисления n! будет иметь вид: var n, i: integer; p: real; begin readln(n); p: =1; for i: =1 to n do p: =p*i; writeln(n, '! =', p: 1: 0);end. Значение факториала накапливается в этой программе в переменной p. Особенность оператора цикла for i: =1 to n do … в том, что если n меньше начального значения i (в данном случае 1), то тело цикла не выполнится ни разу. Поэтому проверять условие, что n> 0 не имеет смысла, так как значение p в этом случае останется равным 1. Для переменной p выбран вещественный тип real, так как функция факториал очень быстро растет (формат печати: 1: 0 означает, что будет печататься только целая часть числа). На основе этой программы легко написать программу, вычисляющую . Вычисление факториала удобно при этом офрмить в виде подпрограммы. Задача 2.4 При решении учтите, что число 0 не относится ни к отрицательным, ни к положительным числам. Задача 2.8 Обозначим: k - номер рейса судна, i - номер очередного груза, s - масса груза на судне в k-том рейсе. Решать задачу будем так: если на судно в k-том рейсе можно поместить ещё один груз, то мы грузим его и берём следующий, если груз не может быть размещен, то перевозим его следующим рейсом (увеличиваем k). Задача 2.10 Вычисление непрерывных радикалов производится в цикле, начиная от внутреннего радикала. В данной задаче начальное значение . Каждое следующее значение радикала будет вычисляться через предыдущее значение радикала по формуле , число изменяется от начального значения 5 до конечного значения 98 с шагом 3. Вычисленное по данной программе значение . Задача 2.11 Вычисление непрерывных дробей производится снизу вверх, начиная от последней. Значение Q 0.69777. Задача 2.13 На каждом шаге данного алгоритма приходится разбивать целое число на отдельные цифры (причем количество цифр в числе неизвестно). Это можно выполнить, используя операции целочисленной арифметики (деления нацело - div и остатка от деления - mod ). Процесс вычисления очередного члена последовательности p через предыдущий в рассматриваемой задаче будет иметь следующий вид ( s и p1 - рабочие переменные, t - очередная цифра числа): s: =0; p1: =p; while p1< > 0 dobegin t: =p1 mod 10; p1: =p1 div 10; s: =s+t*t*t; end; p: =s;Задача 2.18 Любое целое четырехзначное число можно представить в виде: Задача 2.20 Стандартный способ вычисления площади выпуклого многоугольника - разбиение исходного многоугольника на отдельные треугольники (рис.) с последующим вычислением площадей полученных треугольников и их суммированием. Площадь отдельного треугольника можно вычислить, например, по формуле Герона, но в данном случае более удобной будет формула расчета площади треугольника по координатам его вершин: Задача 2.21 Чтобы определить, лежит ли точка внутри треугольника, можно соединить эту точку отрезками с его вершинами и рассчитать площади получившихся треугольников (как в предыдущей задаче). Если сумма вычисленных площадей равна площади исходной фигуры (рис. а), то точка лежит внутри, если нет (рис. б) - снаружи. Задача 2.22 Для решения задачи можно создать массив D(12), каждый элемент которого - число дней в соответствующем месяце. Задача 2.24 Пусть i - номер дня в октябре месяце. Так как 1 октября среда, то 4 и 5 октября будут соответственно суббота и воскресенье. Соответственно, субботами и воскресеньями будут все те дни, которые отличаются от 4 и 5 на целое число недель. Субботами будут дни с такими номерами i, что остаток от деления на 7 равен 4 (i mod 7 = 4), воскресеньями - дни с номерами i, для которых i mod 7 =5. Популярное:
|
Последнее изменение этой страницы: 2017-03-08; Просмотров: 973; Нарушение авторского права страницы