Вопросы для контроля
Улучшенная программа задачи 5.2
/* Программа с использованием цикла с параметром */
#include <stdlib.h>
#include <stdio.h> /* директивы */
#include <math.h> /* препроцессора */
#include <conio.h>
main() /* заголовок основной функции */
{
float c[7], /* массив значений стоимостей кладов */
p[7], /* массив значений начисленных премий */
pro; /* процент вознаграждения */
int n, i, /* размер массивов (количество кладов), параметр цикла */
d, t; /* переменные, определяющие печать на принтер и повторение */
do /* начало цикла для повторения вычислений */
{
clrscr(); /* очистка экрана */
printf("Вывод на печать – 1, \n"
"иначе – другая цифра: "); /* вывод запроса */
scanf("%d", &d); /* ввод значения переменной, определяющей печать на принтер (ответ на запрос) */
printf("Введите размер массива (от 1 до 7): ");
scanf("%d", &n); /* ввод размера массивов */
for( i=0 ; i < n ; i++ ) /* заголовок цикла ввода исходного массива (массив стоимостей кладов) */
{
printf("Введите значение стоимости клада "
"c(%d), тыс. р.: ", i+1);
scanf("%f", &c[i]); /* ввод значения элемента массива */
}
printf("Введите размер вознаграждения, проц. : ");
scanf("%f", &pro); /* ввод значения процента вознаграждения */
/* вывод процента вознаграждения и шапки таблицы на экран */
printf("\n Размер вознаграждения....: %.1f проц. \n", pro);
printf(" +––––––––––––+–––––––––––+\n"
" | Стоимость | Премия |\n"
" | клада c(i) | п(i) |\n"
" +––––––––––––+–––––––––––+\n");
if( d == 1 ) /* проверка условия вывода на принтер */
{
/* вывод процента вознаграждения и шапки таблицы на принтер */
fprintf(stdprn,"\n Размер вознаграждения: "
"%.1f проц. \n", pro);
fprintf(stdprn," +––––––––––––+–––––––––––+\n"
" | Стоимость | Премия |\n"
" | клада c(i) | п(i) |\n"
" +––––––––––––+–––––––––––+\n");
}
for( i=0 ; i < n ; i++ ) /* заголовок цикла вычисления значения функции (расчет премий) */
{
p[ i ] = ( c[ i ] * pro ) / 100.; /* вычисление текущего значения */
/* вывод текущих значений элементов массивов на экран */
printf(" | %7.2f | %8.3f |\n", c[ i ], p[ i ]);
if( d == 1 ) /* проверка условия вывода на принтер */
{
/* вывод текущих значений элементов массивов на принтер */
fprintf(stdprn," | %7.2f | %8.3f |\n"
, c[ i ], p[ i ]);
}
}
printf(" +––––––––––––+–––––––––––+\n");
if( d == 1 ) /* проверка условия вывода на принтер */
{
fprintf(stdprn, " +––––––––––––+–––––––––––+\n");
}
printf("Повторение решения – 1, \n"
"выход – другая цифра: "); /* вывод запроса */
scanf("%d", &t); /* ввод значения переменной, определяющей повторение вычислений (ответ на запрос) */
}while( t==1 ); /* окончание цикла, организующего повторение */
} /* завершающая скобка головной функции */
Численные значения вводимых данных не показаны.
Принципы улучшения дружественности, используемые в программе, являются универсальными и пригодны для алгоритмов и программ любых видов и типов.
1. Что такое улучшение качества программных продуктов и в чём оно заключается?
2. Для чего используются укороченные спецификаторы ввода-вывода?
3. Как влияет максимально укороченный спецификатор на точность выводимых вещественных переменных?
4. Как выглядят фрагменты алгоритмов и программ для организации диалогового ввода переменных?
5. Каковы варианты организации ввода массивов?
6. Как формулируется методика оформления выводимых данных?
7. Как формируются и используются составные присваивания?
8. Каковы фрагменты организации выбора устройства вывода?
9. Для чего и как реализуется в программе повторение расчётов?
10. Что такое позиционирование курсора, как реализуется?