• Пользовательские типы данных объявляют внутри секции TYPE, такие типы данных делают программу гибче и надежней.
• Размер памяти, занимаемый переменной любого типа, определяют псевдофункцией SizeOf. Её применение снижает зависимость программы от особенностей компиляторов и компьютерных платформ.
А) Напишите две функции, округляющие вещественное число:
• до большего значения (например: 3.1 –> 4; 3.9 –> 4);
• до меньшего значения (например: 3.1 –> 3; 3.9 –> 3).
Б) Ваша процедура принимает строковую переменную, вычисляет среднее арифметическое кодов её символов и печатает его с двумя цифрами после точки.
В) Напечатайте с тремя знаками после точки 20 случайных вещественных чисел в диапазоне от 0 до 10. Подсказка
: для формирования дробных чисел можно делить случайное число на другое число, например, Random(10000)/1000.Г) Напечатайте с тремя знаками после точки 20 случайных чисел в диапазоне от 0 до 10 так, чтобы числа следовали по возрастанию. Подсказка: сравнивайте очередное число с предыдущим.
Д) Программа для подсчета стоимости покупок. Для каждой покупки пользователь вводит два действительных числа: вес покупки и цену за 1 кг в рублях. Признак завершения ввода данных – нулевой вес. Программа должна напечатать общую стоимость с точностью до копейки (два знака после точки) с округлением в большую сторону. Проверьте результат на калькуляторе.
Е) Квадратный корень. Квадрат – это равносторонний прямоугольник, его площадь вычисляется по формуле S=D•D, где D – сторона квадрата. А когда площадь S известна, и надо определить сторону D? Тогда из S извлекают квадратный корень (обозначается символом
Для извлечения корня в Паскале есть функция SQRT. Напишите собственную функцию MySQRT, прибегнув к методу последовательных приближений. В грубом, нулевом приближении примем D0
=1. Последующее, более точные значения D будем вычислять по формулеDi+1
= (Di + S/Di)/2Так, при S=9 получим D1
=(1+9/1)/2= 5, D2=(5+9/5)/2=Ж) В тесто кладут четырех главных ингредиента: муку, сахар, яичный порошок и молоко. Все это смешивается в пропорции, заданной рецептом. Например, рецепт 100:5:7:500 означает, что на 100 граммов муки кладут 5 граммов сахара, 7 граммов яичного порошка и 500 граммов молока. У пекаря есть некоторое количество всех ингредиентов, и он хочет замесить из них максимально возможное количество теста, соблюдая рецепт. Ваша программа должна ввести:
• Рецепт – это 4 целых числа.
• Исходное количество ингредиентов – это 4 действительных числа.
Программа должна напечатать:
• Общее количество полученного теста с точностью два знака после точки.
• Остатки ингредиентов – 4 числа с точностью два знака после точки.
Глава 34
Структура программы
В этой главе мы рассмотрим структуру программы, и завершим тем самым боевое построение нашего войска, начатое в 32-й главе.
Управляющие структуры составляют основу языков программирования. Ключевых структур всего три:
• линейная последовательность – это естественный порядок выполнения операторов друг за другом, то есть слева направо и сверху вниз;
• альтернатива – выбор одного из двух или нескольких направлений исполнения операторов;
• цикл – повторное исполнение операторов до соблюдения некоторого условия.
Альтернатива и цикл представлены в Паскале несколькими операторами, из которых программист выбирает тот, что лучше подходит к решаемой задаче (рис. 77).
Итак, для организации альтернативы может быть использован один из трех операторов:
• неполный условный оператор IF-THEN;
• полный условный оператор IF-THEN-ELSE;
• оператор выбора CASE-OF-ELSE-END.
Для организации циклов программист также применяет три оператора:
• цикл с проверкой условия в конце REPEAT-UNTIL;
• цикл с проверкой условия в начале WHILE-DO;
• цикл со счетчиком FOR-TO-DO и FOR-DOWNTO-DO.
Обратите внимание на условия продолжения циклов WHILE-DO и REPEAT-UNTIL, – они взаимно противоположны! Первый из них выполняется, пока условие истинно, а второй – пока оно ложно.
Странно, что из этих немногих структур лепятся столь сложные программы!
Программа на Паскале состоит из ряда секций (Section – «часть», «раздел»). Под структурой программы будем понимать взаимное положение этих секций. На рис. 78 показана упрощенная структура программы.