Цикл с постусловием.
Цикл с предусловием.
Программирование циклов
В Си существуют три типа операторов цикла:
· цикл с предусловием;
· цикл с постусловием;
· цикл с параметром.
Формат оператора цикла с предусловием:
while (выражение) оператор;
Цикл повторяет свое выполнение пока значение выражения отлично от нуля, т. е. заключенное в нем условие цикла истинно.
Пример:
программа вычисления факториала целого положительного числа N!=1*2*3*…*N.
// Программа вычисления факториала
#include <iostream.h>
void main()
{
long int F;
int i;
// соut<<"N="; cin>>N;
F=i=1;
while (F<=2147….) F=F*i++;
N=i
соut<<"\n"<<N<<"!=<<F;
}
Факториал — очень быстро растущая функция, и поэтому при определенных значениях N выйдет из диапазона, соответствующего типу long int. Задав для переменной F тип unsigned long, можно сдвинуть эту границу, но этого может оказаться недостаточно.
Самостоятельное задание: исследовать предельные значения N для двух указанных типов переменной F.
Пример:
while(1);
Свойство следующего оператора: это бесконечный пустой цикл. Использование в качестве выражения константы 1 приводит к тому, что условие повторения цикла все время остается истинным и работа цикла никогда не заканчивается. Тело в этом цикле представляет собой пустой оператор. При исполнении такого оператора программа будет «топтаться на месте».
Пример: задача итерационного вычисления суммы гармонического ряда: S=0+1+1/2+1/3+...+1/n+… с заданной точностью ε.
// Программа вычисления суммы гармонического ряда
#include <iostream.h>
#include <limits.h>
void main()
{ int n=1;
double S=0, eps;
соut<<"Точность:"; cin>>eps;
while (1./n>eps && n<INT_MAX) S+=1./n++;
соut<<"\n Сумма=" <<S;
}
Файл limits.h, подключаемый препроцессором, содержит определения предельных констант для целых типов данных. В частности, константа с именем INT_MAX равна максимальному значению типа int в данной реализации компилятора. Если для типа int используется двухбайтовое представление, то INT_MAX=32767. В этом же заголовочном файле определены и другие константы: INT_MIN=-32768; LONG_MAX=2147483647 и т.д.
Формат оператора цикла с постусловием:
do оператор while (выражение);
В операторе do ... while условие повторения цикла пишется в конце. Цикл выполняется до тех пор, пока выражение отлично от нуля, т.е. заключенное в нем условие цикла истинно.
Выход из цикла происходит после того, как значение выражения станет ложным, иными словами равным нулю.
Пример: программа вычисления N!, в которой используется цикл с постусловием.
// Программа вычисления факториала
#include <iostream.h>
void main()
{
long int F;
int i, N;
соut<<"N="; cin>>N;
F=i=1;
do F*=i++; while (i<=N);
соut<<"\n"<<N<<"!=<<F;
}