Оператор цикла с параметром
Оператор цикла применяется при выполнении расчетов или других действий, повторяющихся определенное количество раз. Оператор имеет вид:
For i:= N1 To N2 Do "оператор";
либо
For i:= N1 DownTo N2 Do "оператор";
Здесь i - параметр цикла (переменная порядкового типа),
N1, N2 - начальное и конечное значения параметра цикла i.
N1, N2 могут быть константами, переменными или выражениями порядкового типа.
Напомним, что "оператор" может иметь вид: Begin "операторы" end;
Схема выполнения оператора цикла с параметром имеет вид:
В случае связки Toцикл выполняется
FOR iпри условии N1 <= N2и происходит
с единичным возрастанием параметра цикла i
от N1 до N2.
от N1 до N2 В случае связки DownTo цикл выполняется
при условииN1 >= N2и происходит
с единичным уменьшением параметра цикла i
DOот N1 до N2.
"оператор" В операторе цикла не разрешается
присваивать параметру цикла какое-либо значение.
После окончания цикла значение параметра цикла “i” неопределенно.
Оператор цикла часто применяется для суммирования значений некоторой последовательности чисел или значений функции при известном числе операций суммирования. Напомним некоторые определения, связанные с расчетом суммы последовательности.
Сумма членов последовательности величин a1, a2, a3, . . . , aN называется конечной суммой SN= a1 + a2 + a3+ . . . + aN. Для некоторых последовательностей известны формулы расчета конечных сумм, например:
при aN= aN-1 + d; SN= (a1 + aN)*N/2; - арифметическая прогрессия,
при aN= aN-1 * q; SN= (a1 - aN*q)/(1-q); - геометрическая прогрессия,
где d и q - постоянные числа.
Здесь N-ый член последовательности выражается через (N-1)-ый член. Такие зависимости называются реккурентными.
Конечная сумма последовательности может быть неизвестна, тогда для ее расчета применяется алгоритм суммирования членов последовательности в цикле от 1 до N. Приведем пример расчета конечной суммы последовательности:
12 + 32 + 52 +. . . + (2*N-1)2; SN = N*(4*N2-1)/3;
PROGRAM SUM_K;{ расчет конечной суммы }
var a, S, Sn, i, N: word;
Begin
write('Введите число членов суммы N='); readln(N);
S:= 0;
For i:= 1 to N do begin{ цикл суммирования }
a:= Sqr(2*i-1); S:= S+a end;
Sn:= N*(4*N*N-1) div 3;
Writeln('Конечная сумма S=', S:-10:2);
Writeln('Расчет конечной суммы по формуле Sn=', Sn:-10:2);
Writeln('Нажми Enter'); readln
End.
Практическое задание N 1. 9
Рассчитать конечные суммы последовательностей:
1) 13 + 23 + 33 +. . . + N3; SN = N2*(N+1)2/4;
2) 13 + 33 + 53 +. . . + (2*N-1)3; SN = N2*(2*N2-1);
3) (X3+1)/cos(1) + (X3+2)/cos(4) + (X3+3)/cos(9) + (X3+N)/cos(N2);
4) (X2+1)/sin(1) + (X2+2)/sin(2) + (X2+3)/sin(3) + (X2+N)/sin(N);
В некоторых случаях "N"-ый член последовательности определяется через сумму предыдущих членов, например, aN= p*SN-1, тогда SN= SN-1 + aN = SN-1*(1+р), и конечную сумму можно рассчитать по формуле:
SN= S0*(1+p)N, где "S0" - начальная сумма.
Рассмотрим программу вычисления конечной суммы денежного вклада в банк через N месяцев при ежемесячной процентной ставке "pr" (5% cоответствует pr=5).
PROGRAM VKLAD;{ расчет конечной суммы вклада в банк }
var S, Sn, pr: real; i, N: integer;
Begin
Write('Введите начальную сумму вклада S='); readln(S);
Write('Введите процент по вкладу pr='); readln(pr);
Write('Введите количество месяцев вклада N='); readln(N);
For i:= 1 to N do S:= S*(1+pr/100. );{ цикл произведений }
Writeln('Конечная сумма вклада S=', S:-10:2);
{ Оператор для расчета "Sn" напишите самостоятельно }
Writeln('Расчет конечной суммы вклада по формуле Sn=', Sn:-10:2);
Writeln('Нажмите Enter');
Readln
End.
Практическое задание N 1. 10
1. Вычислить конечную сумму денежного вклада в рублях при открытии валютного счета в банке через несколько месяцев при ежемесячной процентной ставке 1% и росте курса валютной единицы по отношению к рублю 2% в месяц. Программа запрашивает ввод суммы и срока вклада, и выводит на экран конечную сумму в рублях. Проверить расчет вычислением по формуле: SN = S0 * (1+pv)N * (1+pi)N,
где pv, pi - банковский и инфляционный коэффициенты.
2. В п. 1 сделать ежемесячный ввод банковской процентной ставки и роста курса валюты при подсчете конечной суммы.
Часто применяются вложенные операторы цикла.Например, если необходимо провести все варианты расчета при изменении нескольких параметров в заданных диапазонах.
Составим программу расчета функции y = A*sin(x) - cos(x)/A; при изменении аргумента "x" в диапазоне от 0 до Pi с шагом Pi/100 и при изменении параметра "A" в диапазоне от 1 до 3 с шагом 0. 5.
Program tabl;
var y, x, a, dx: real; i, j: integer;
Begin
Writeln(' Расчет по формуле: y=A*sin(x)-cos(x)/A; ');
Writeln('--------------------------------------------------');
Writeln('|___X___|__A=1.0_|_A=1.5_|_A=2.0_|_A=2.5_|_A=3.0_|');
Writeln('--------------------------------------------------');
dx:= pi/100;
for i:= 0 to 100 do begin{ внешний цикл изменения аргумента "X" }
x:= dx*i; Write( x:8:4 );
for j:= 1 to 5 do begin{ вложеннный цикл изменения параметра "A" }
A:= 0.5*(j+1); y:= A*sin(x)-cos(x)/A; Write(y:8:4)
end;
Writeln;{ перевод курсора на новую строчку }
if ((i+1) mod 20) = 0 then
readln{ задержка прокрутки экрана до нажатия Enter }
End; readln
End.
Практическое задание N 1. 11
1. Рассчитать значения функции y = sin(x)/(x+a)2 при изменении аргумента "x" в диапазоне от 0 до Pi/2 с шагом Pi/80 и при изменении параметра "A" в диапазоне от 1 до 2 с шагом 0, 2.
2. Рассчитать значения функции y = xa/a3 при изменении аргумента "x" в диапазоне от 1 до 10 с шагом 0, 2 и при изменении параметра "A" в диапазоне от 1 до 5 с шагом 1.
Составим программу численной проверки неравенства Коши:
Ö(a1 * a2 *. . . * aN) £ ( a1 + a2 +. . . + aN )/N; где a1, a2, . . . , aN > 0,
в частном случае двух целых чисел в диапазоне от 1 до 250.
Примечание: погрешности в вычислениях могут привести к неверному выводу, поэтому формулы преобразованы для расчета целых чисел!
Program TEOREMA; {проверка теоремы о ср. арифметическом и ср. геометрическом }
var a1, a2, N1, s, g: longint; bb: boolean;
Begin bb:= true; Writeln ('Процесс пошел, ждите!');
N1:= 250;
For a1:= 1 to N1 do{ внешний цикл }
For a2:= 1 to N1 do begin{ вложенный цикл }
S:= (a1+a2)*(a1+a2); G:= 4*a1*a2;
if S < G then bb:= false end;
If bb = true then Writeln ('Теорема верна')
else Writeln ('Теорема не верна');
Не нашли, что искали? Воспользуйтесь поиском по сайту:
©2015 - 2024 stydopedia.ru Все материалы защищены законодательством РФ.
|