исправить.сил больше нет begin var f: real-> real: =x-> 0.1*(sin(x)/cos(.1*x+0,0025*x*x); ; var (a,b): =readreal2('введите границы интервала: '); var (fa,fb): =(f(a),f(b)); var eps: =readreal('введите требуемую точность: '); var n: =1; writeln(' n',12*' ','x',14*' ','y'); while true do begin var x: =(a+b)/2; var y: =f(x); if (abs(y) writeln(n: 3,x: 15: 6,y: 15: 6); if sign(fa)=sign(y) then a: =x else b: =x; n+=1 end end.

KaKTyZzZz KaKTyZzZz    1   07.04.2019 09:44    0

Ответы
Ксения200612 Ксения200612  28.05.2020 19:00

Ошибки (в программе на картинке):

1) (sin(x)/cos(x))(0.1*x+0,0025*x*x) - между скобками отсутствует знак операции

2) (0.1*x+0,0025*x*x) - вместо 0,0025 нужно писать 0.0025

3)  (0.1 * (sin(x) / cos(x)) * (0.1 * x + (0.0025 * x * x)); - в конце лямбда-выражения перед ; не хватает )

Исправленная программа:

begin

 

 var f: real-> real := x -> (0.1 * (sin(x) / cos(x)) * (0.1 * x + (0.0025 * x * x)));  

 var (a, b) := ReadReal2('Введите границы интервала:');

 var (fa, fb) := (f(a), f(b));

 var eps := ReadReal('Введите требуемую точность:');

 var n := 1;

 Writeln(' n', 12 * ' ', 'x', 14 * ' ', 'y');  

 while True do

 begin

   var x := (a + b) / 2;

   var y := f(x);

   if (Abs(y) < eps) and (Abs(b - a) < eps) then break;

   Writeln(n:3, x:15:6, y:15:6);

   if Sign(fa) = Sign(y) then a := x else b := x;

   n += 1

 end

end.

ПОКАЗАТЬ ОТВЕТЫ
Другие вопросы по теме Информатика