Показать сообщение отдельно
Старый 31.03.2013, 14:48   #2 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Цитата:
Сообщение от anasteishen Посмотреть сообщение
должны выводиться шаг...
Никаких "шагов" данные методы не предусматривают.
Цитата:
Сообщение от anasteishen Посмотреть сообщение
методами простой итерации
Код:
Const
 Eps=0.0001;

Var
 x,x_bef,d:real;

Function Fi(z:real):real;
begin
 Fi:=2*Exp(-z);
end;

Begin
 x_bef:=0;
 Repeat
  x:=Fi(x_bef);
  Writeln('x= ',x:5:3,'    x*Exp(x)= ',x*Exp(x):5:3);
  d:=Abs(x_bef-x);
  x_bef:=x;
 Until d<Eps;
 Writeln('Result: x= ',x:8:6);
 Readln
End.
Цитата:
Сообщение от anasteishen Посмотреть сообщение
и методом Ньютона
Код:
Const
 Eps=0.0001;

Var
 x,x_bef,d:real;

Function F(z:real):real;
begin
 F:=2.0-z*Exp(z);
end;

Function Der(z:real):real;
begin
 Der:=-(z+1)*Exp(z);
end;

Begin
 x_bef:=0;
 Repeat
  x:=x_bef-F(x_bef)/Der(x_bef);
  Writeln('x= ',x:5:3,'    x*Exp(x)= ',x*Exp(x):5:3);
  d:=Abs(x_bef-x);
  x_bef:=x;
 Until d<Eps;
 Writeln('Result: x= ',x:8:6);
 Readln
End.
Vladimir_S вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070