Итерационные алгоритмы и программы. Лекция 7

Содержание

Слайд 2

В итерационных циклах производится проверка некоторого условия, и в зависимости от

результата этой проверки происходит либо выход из цикла, либо повторение выполнения тела цикла. Если проверка условия производится перед выполнением блока операторов, то такой итерационный цикл называется циклом с предусловием (цикл "пока"), а если проверка производится после выполнения тела цикла, то это цикл с постусловием (цикл "до").
Особенность этих циклов заключается в том, что тело цикла с постусловием всегда выполняется хотя бы один раз, а тело цикла с предусловием может ни разу не выполниться. В зависимости от решаемой задачи необходимо использовать тот или иной вид итерационных циклов.
В итерационных циклах производится проверка некоторого условия, и в зависимости

Слайд 3

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

Оператор повтора repeat состоит из
заголовка (repeat),
тела
условия окончания (until).


repeat
Инструкции
until Условие_выхода_из_цикла;
Условие выхода из цикла — это выражение логического типа.
Цикл с постусловием Оператор повтора repeat состоит из заголовка (repeat),

Слайд 4

Описание работы

Цикл работает так: вначале выполняется тело цикла — инструкции, которые

находятся между repeat и until, затем проверяется значение Условия выхода из цикла. В том случае, если оно равно false (ложь), т. е. не выполняется, — инструкции цикла повторяются еще раз. Так продолжается до тех пор, пока условие не станет true (истина).
Для успешного завершения цикла repeat в его теле обязательно должны находиться инструкции, выполнение которых влияет на условие завершения цикла, иначе цикл будет выполняться бесконечно — программа зациклится. Т.е., переменная, которая участвует в условии выхода из цикла, обязательно должна изменяться в теле цикла;
Нижняя граница операторов тела цикла четко обозначена словом until, поэтому нет необходимости заключать эти операторы в операторные скобки begin и end.
Описание работы Цикл работает так: вначале выполняется тело цикла —

Слайд 5

Цикл repeat — это цикл с постусловием, т. е. инструкции тела

цикла будут выполнены хотя бы один раз. Поэтому цикл repeat удобно использовать в тех случаях, когда тело цикла гарантированно должно выполниться хотя бы один раз.
 Оператор repeat часто используют для проверки правильности ввода исходных данных, т. к. это именно тот самый случай, когда тело цикла гарантированно выполняется один раз, а при наличии ошибки в исходных данных — более одного раза.
var с: char;
begin
repeat
writeln(‘ Введите Y или N');
readln(с);
until (с='Y’) or (c=’N’);
end.
Цикл repeat — это цикл с постусловием, т. е. инструкции

Слайд 6

Цикл repeat удобно использовать для обработки ошибки ввода при несоответствии типа

введенных данных типу переменной.
В Pascal предусмотрена возможность отключения стандартного контроля ошибок ввода при помощи директивы компилятора {$I-}, а контроль правильности ввода выполняет стандартная функция ioResult. Эта функция имеет нулевое значение, если последняя операция ввода/вывода закончилась успешно, и ненулевое значение, равное коду ошибки, если ввод/вывод закончился неудачей.
После вызова функция ioResult сбрасывает свое значение, поэтому обычно ее значение сразу присваивается какой-либо переменной. Рекомендуется после анализа результата, возвращаемого ioResult, снова установить стандартный контроль ошибок ввода/вывода с помощью директивы {$I+}.
Цикл repeat удобно использовать для обработки ошибки ввода при несоответствии

Слайд 7

var
х: integer; ok: boolean;
begin
repeat
writeln('Введите целое x');
{$i-} {отмена

стандартного контроля оп-й ввода/вывода }
readln(x);
{$i+} {включение стандартного контроля оп-й вв/вывода}
until ioresult=0;
end.
var х: integer; ok: boolean; begin repeat writeln('Введите целое x');

Слайд 8

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

while Условие_выполнения_цикла do
begin
Инструкции
end;
Условие выполнения цикла —

это выражение логического типа. Тело цикла — оператор, чаще всего составной. Если тело цикла представляет собой одиночный оператор, то ключевые слова begin и end лучше не писать, хотя их наличие не будет ошибкой.
Цикл с предусловием while Условие_выполнения_цикла do begin Инструкции end; Условие

Слайд 9

Описание работы

Цикл while работает так: вначале выполняется проверка значения Условие выполнения

цикла — если значение условия равно true (истина), то выполняются инструкции цикла, находящиеся между begin и end и снова вычисляется выражение Условие выполнения цикла. Так продолжается до тех пор, пока значение Условие выполнения цикла не станет равно false (ложь).
Описание работы Цикл while работает так: вначале выполняется проверка значения

Слайд 10

Пример. Найти НОД двух натуральных чисел, используя алгоритм Евклида.
var
a, b:integer;
begin

writeln(‘Введите два натуральных числа’);
readln(a, b);
while a<>b do
if a>b then a:=a-b
else b:=b-a;
writeln(‘НОД=’, a);
readln;
end.
Пример. Найти НОД двух натуральных чисел, используя алгоритм Евклида. var

Слайд 11

Пример. Пользователь вводит целое положительное число. Определите, какое минимальное количество последовательно

расположенных натуральных чисел необходимо сложить, чтобы их сумма превзошла введенное пользователем число.

var n,i,s:integer;
begin
writeln('Vvedite chislo');
readln(n);
i:=0;
s:=0;
repeat
i:=i+1;
s:=s+i;
until s>n;
writeln('kolichestvo =',i);
readln;
end.

var n,i,s:integer;
begin
writeln('Vvedite chislo');
readln(n);
i:=0;
s:=0;
while s<=n do
begin
i:=i+1;
s:=s+i;
end;
writeln('kolichestvo =',i);
readln;
end.

Пример. Пользователь вводит целое положительное число. Определите, какое минимальное количество

Слайд 12

Численные методы решения алгебраических и трансцендентных уравнений

Дано нелинейное уравнение: f(x)=0.
Если функцию

можно привести к виду
f(x)=a0xm+ a1xm-1+ a2xm-2+…+ am-1x+ a0,
где ai - коэффициенты многочлена, , то уравнение f(x)=0 называется алгебраическим.
Если функция f(x) включает в себя тригонометрические или экспоненциальные функции от некоторого аргумента x и т.д., то уравнение называется трансцендентным уравнением.
Как известно, не всякое уравнение может быть решено точно. В первую очередь это относится к большинству трансцендентных уравнений.
Численные методы решения алгебраических и трансцендентных уравнений Дано нелинейное уравнение:

Слайд 13

Однако точное решение уравнения не всегда является необходимым. Задачу отыскания корней

уравнения можно считать практически решенной, если мы сумеем найти корни уравнения с заданной степенью точности. Для этого используются приближенные (численные) методы решения.
Большинство употребляющихся приближенных методов решения уравнений являются, по существу, способами уточнения корней. Для их применения необходимо знание интервала изоляции [a,b], в котором лежит уточняемый корень уравнения.
Однако точное решение уравнения не всегда является необходимым. Задачу отыскания

Слайд 14

Процесс определения интервала изоляции [a,b], содержащего только один из корней уравнения,

называется отделением этого корня.
Процедура отделения корней основана на известном свойстве непрерывных функций: если функция непрерывна на замкнутом интервале [a,b] и на его концах имеет различные знаки, т.е. f(a)f(b)<0, то между точками a и b имеется хотя бы один корень уравнения. Если при этом знак функции f'(x) на отрезке [a,b] не меняется, то корень является единственным на этом отрезке.
Процесс определения корней алгебраических и трансцендентных уравнений состоит из 2 этапов:
отделение корней, - т.е. определение интервала [a,b], внутри которого лежит корень уравнения;
уточнение корней, - т.е. сужение интервала [a,b] до величины равной заданной степени точности .
Процесс определения интервала изоляции [a,b], содержащего только один из корней

Слайд 15

Метод половинного деления

 

Метод половинного деления

Слайд 17

Const e=0.001;
Var x, t, a, b:real;
function f1(x:real):real;
begin
f1:=sin(x);
end;
begin
writeln(‘Введите

a, b’);
readln(a, b);
repeat
t:=(a+b)/2;
if f1(a)*f1(t)<=0 then b:=t else a:=t;
until abs(b-a)<=e;
x:=(b+a)/2;
writeln(‘Корень равен’, x:7:4); end.
Const e=0.001; Var x, t, a, b:real; function f1(x:real):real; begin

Слайд 18

Метод простых итераций

 

Метод простых итераций

Слайд 20

Метод Ньютона (метод касательных)

Метод Ньютона относится к градиентным методам, в которых

для нахождения корня используется значение производной.
Дано нелинейное уравнение: f(x)=0. Найти корень на интервале [a,b] с точностью ε.
Метод Ньютона основан на замене исходной функции f(x), на каждом шаге поиска касательной, проведенной к этой функции. Пересечение касательной с осью Х дает приближение корня.
Выберем начальную точку x0=b (конец интервала изоляции). Находим значение функции в этой точке и проводим к ней касательную, пересечение которой с осью Х дает нам первое приближение корня x1.
Метод Ньютона (метод касательных) Метод Ньютона относится к градиентным методам,

Слайд 22

Метод хорд

Метод основан на замене функции f(x) на каждом шаге поиска

хордой, пересечение которой с осью Х дает приближение корня.
При этом в процессе поиска семейство хорд может строиться:
а) при фиксированном левом конце хорд, т.е. z=a, тогда начальная точка х0=b;
б) при фиксированном правом конце хорд, т.е. z=b, тогда начальная точка х0=a;
Метод хорд Метод основан на замене функции f(x) на каждом
Имя файла: Итерационные-алгоритмы-и-программы.-Лекция-7.pptx
Количество просмотров: 46
Количество скачиваний: 0