Занятие № 2
Если какой-либо фрагмент алгоритма должен быть выполнен многократно, то это циклический алгоритм (цикл).
Циклические алгоритмы можно условно разделить на две группы.
1. Арифметический цикл, у которого заранее известно число повторений.
2. Итерационный цикл, у которого заранее неизвестно число повторений.
Управление циклом выполняет некоторая переменная величина, которая называется «параметр цикла» или «управляющая переменная».
Это переменная программы, которая, как правило, изменяется в теле цикла, определяет число повторений цикла и позволяет вовремя завершить его работу.
Можно выделить четыре составные части цикла.
1. Подготовка цикла: присваивание начальных значений переменным, в том числе параметру цикла.
2. Тело цикла: фрагмент, который должен быть повторен многократно.
3. Изменение параметра цикла: как правило, выполняется в теле цикла.
4. Проверка условия завершения цикла: в проверке условия, явно или нет,присутствует параметр цикла.
Не всегда эти составляющие присутствуют явным образом.
Cуществуют три вида операторов цикла, которые одинаково можно использовать для организации любого циклического алгоритма.
while (Условие)
{ //
Тело цикла
}
do
{ //
Тело цикла
} while (Условие)
for (объявление параметра цикла)
{ //
Тело цикла
}
Пример 1:
Алгоритм построения таблиц значений различных функций. Это,
чаще всего, арифметический цикл. Обычно параметром цикла является аргумент функции. Для функции задана формула вычисления значения
`y(x)\ =\ F(x)`.
Известны диапазон изменения аргумента
`x_0\ ≤\ x\ ≤\ x_n`, и шаг изменения dx.
Общая схема этого алгоритма на основе цикла while (Pascal) выглядит так:
x = x0; //
while x <= xn do //
begin
y = F(x); //
//
x += dx; //
end; //
Общая схема этого алгоритма на основе цикла do … while на языке Pascal выглядит так:
x = x0; //
repeat
y = F(x); //
//
x += sx; //
until (x > xn); //
Общая схема этого алгоритма на основе цикла for языка Си выглядит так:
for (x = x0; x <= xn; x += dx) //
{
y = F(x); //
//
};
В алгоритмах вычисления сумм, произведений, количеств, пределов, последовательностей особенностью является содержание тела цикла.
При вычислении суммы к значению суммы многократно прибавляются новые значения слагаемых.
При вычислении произведения значение многократно умножается на очередной сомножитель.
При вычислении количеств значение счётчика увеличивается на 1.
При вычислении предела или последовательности значение многократно вычисляется на базе предыдущего значения.
Итоговое значение, кроме вычисления последовательностей, чаще единственное, так как все остальные вычисленные значения являются промежуточными.
Управление циклами этого вида выполняется также с использованием
управляющих переменных, которыми фактически служит номер вычисляемого значения (слагаемого, множителя, элемента последовательности).
Если число повторений известно, цикл должен быть арифметическим. В задачах вычисления с указанной точностью цикл должен быть итерационным, так как заранее не
может быть известно число повторений, которое понадобится, чтобы достичь заданной точности.
Пример 2. Вычисление суммы известного числа слагаемых. Пусть
требуется вычислить сумму
`N` чисел натурального ряда
`S\ =\ 1\ +\ 2\ +\ 3\ +\ 4\ +\ …\ +\ N`, где
`N` – любое наперед заданное число.
Это арифметический цикл, у которого параметром является номер слагаемого,который также определяет и значение очередного слагаемого, включаемого в сумму. Обозначим его буквой n, тогда общая формула тела цикла запишется так:
`S=S+n`
Смысл цикличности в том, что к значению суммы многократно прибавляются новые значения слагаемых, обновляя ее. Число повторений цикла равно числу действий сложения, которое нужно выполнить, чтобы достичь результата.
Номер слагаемого (и его значение)
`n` меняется в диапазоне от 1 до
`N` с шагом, равным 1.
//
int main (void)
{
int n; //
int S; //
int N; //
scanf ("%d", &N);
S = 0; //
n = 1; //
do
{
S += n; //
n ++; //
} while (n <= N);
//
printf ("%d", S);
return 0;
} //
Поскольку данный цикл арифметический, использование оператора цикла do … while не необходимо, но подчёркивает, что любой тип цикла в С++ можно реализовать с помощью любого оператора цикла.
Пример 3.Организация итерационного цикла на примере алгоритма суммирования. Пусть требуется найти сумму прогрессии
`S=1+1/2+1/3+…+1/n+…` c точностью
`"eps"` (например,
`"eps"`= 0.001).
Количество слагаемых, которое нужно включить в сумму для достижения заданной точности, неизвестно, но известно условие, определяющее точность вычислений.
Предел значения очередного слагаемого стремится к нулю при
`n`, стремящемся к бесконечности.
поэтому можно считать, что именно это значение определяет требуемую точность вычислений, и можно закончить вычисления, когда очередное слагаемое настолько мало, что им можно пренебречь. Все переменные должны иметь вещественный тип, так как участвуют в вычислении вещественного значения.
//
int main (viod)
{
double S;
double eps; //
double n; //
//
scanf ("%lf", &eps);
n = 1;
S = 0; //
do
{
S += 1. / n;
n += 1;
} while ( 1. / n >eps); //
printf("%8.5lf", S);
return 0;
} //
В рассмотренных примерах циклические алгоритмы суммирования являются простыми. При организации сложных циклов внутренний цикл полностью, от подготовки до завершения должен находиться внутри внешнего.