Технический форум
Вернуться   Технический форум > Программирование > Форум программистов > Delphi, Kylix and Pascal


Ответ
 
Опции темы Опции просмотра
Старый 31.03.2013, 11:55   #1 (permalink)
anasteishen
Новичок
 
Регистрация: 31.03.2013
Сообщений: 1
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
Exclamation Помогите написать программу на Паскале

Дано нелинейное уравнение 2-x*exp(x).
Реализовать на языке Pascal программы приближенного решения нелинейного уравнения методами простой итерации и методом Ньютона). В результате должны выводиться шаг, x, точность, погрешность и конечный х.
Найти решение с точностью 0.0001.
anasteishen вне форума   Ответить с цитированием

Старый 31.03.2013, 11:55
Helpmaster
Member
 
Аватар для Helpmaster
 
Регистрация: 08.03.2016
Сообщений: 0

Пожалуйста, уделите внимание просмотру данных тем

Помогите написать программу в паскале
Помогите написать программу в Паскале
Пожалуйста, помогите написать программу в Паскале.
Ребята помогите написать программу на паскале

Старый 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
Ответ


Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.
Trackbacks are Вкл.
Pingbacks are Вкл.
Refbacks are Выкл.




Часовой пояс GMT +4, время: 23:55.

Powered by vBulletin® Version 6.2.5.
Copyright ©2000 - 2014, Jelsoft Enterprises Ltd.