Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Цикл с постусловием




Цикл с предусловием.

Программирование циклов

В Си существуют три типа операторов цикла:

· цикл с предусловием;

· цикл с постусловием;

· цикл с параметром.

Формат оператора цикла с предусловием:

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;

}





Поделиться с друзьями:


Дата добавления: 2014-01-06; Просмотров: 403; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.01 сек.