Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
PraktikumC.pdf
Скачиваний:
73
Добавлен:
10.02.2015
Размер:
1.1 Mб
Скачать

38

scanf("%d %u %f %lf",&k,&j,&x,&y); printf("%d \t%u \t%g \t%g",k,j,x,y);

2. сравнение в программе с помощью операторов if или while (см. далее раздел «Программы разветвляющейся структуры» и «Программы циклической структуры») количества переменных в списке ввода функции scanf, с количеством фактически прочитанных из входного потока чисел, возвращаемым функцией (если оно 0, значит ошибка возникла до ввода первого числа, если 1, значит было прочитано только одно число и т.д.) и при несовпадении указанных количеств организовать либо повторный ввод, либо вывод соответствующего сообщения и выход из программы, либо какую-то другую обработку.

2.2 Приемы, используемые для минимизации вычислений

Одним из критериев, характеризующих качество составленной программы, является объем выполняемых ею вычислений для достижения требуемого результата. Чем он меньше, тем, как правило, быстрее будет работать программа. Существуют разные приемы, применение которых позволяет сократить объем вычислений за счет уменьшения в первую очередь количества вызовов функций, затем – количества операций типа умножения, и, наконец, – количества операций типа сложения. Вот некоторые из них, рассмотренные отдельно, хотя, как правило, они используются в сочетании.

Вынесение общих множителей за скобки. Например, вместо оператора

Z=sin(X)*Y-sin(X)*sqrt(Y)*Y+sqrt(X)*X+X;

лучше использовать оператор

Z=sin(X)*Y*(1-sqrt(Y))+X*(sqrt(X)+1);

Использование схемы Горнера для полиномов. Например, полином

2X5 - 5X4 +2X3 +7X2 - 4X +6

преобразованный по схеме Горнера, примет вид

((((2X-5)X+2)X+7)X-4)X+6

где явно меньше число операций умножения, если считать, что возведение в степень выполняется через умножение. В программе по второму варианту записи полинома будем иметь выражение

((((2*X-5)*X+2)*X+7)*X-4)*X+6,

а по первому –

2*pow(X,5)-5*pow(X,4)+2*pow(X,3)+7*pow(X,2)-4*X+6

Ю. Е. Алексеев, А. В. Куров «Практикум по программированию на языке C в среде VS C++» Оглавление

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]