Всем доброго времени суток! Вот возникла проблемка... Немогу связать 2 процедуры для подсчета arctg(x) через ряд Тейлора... проблема в локальных/глобальных переменных или еще передачу по ссылке или по значению где нить напутал 100%... я в тупике. Пжжалста помогите, кто нить!!!
Вот так вот я ее написал:
Program finish;
uses CRT;
Var x,xmin,n,j,xmax,f,dx,eps,q,c,k,m:real;
procedure input(var a:real);
begin
read(a);
end;
procedure arctg(x:real;var f:real);
begin
c:=1;
n:=0;
f:=0;
repeat
j:=-(2*n-1)/((2*n-1)*x*x);
c:=c*j;
f:=f+c;
until abs(f)<eps;
end;
procedure tab(xmin,xmax,q,x:real;var c:real);
begin
k:=0;
x:=xmin;
writeln ('x po Teyloru chislo chlenov arctan(x) ');
while x<=xmax do begin
arctg(x,f);
m:=arctan(x);
k:=k+1;
x:=x+dx;
writeln(x:2:2,' ', c:4:4{zn-e arctg(x)},' ', k:4:1,' ', m:4:4) ;
end;
end;
Begin
clrscr;
writeln('programma vichislyaet znachenie funkcii arctg(x) s pomoshu ryada Teylora');
write('vvedite xmin:');
input(xmin);
write('vvedite xmax:');
input(xmax);
write('vvedite step:');
input(dx);
write('vvedite tochnost:');
input(eps);
tab (xmin,xmax,q,x,c);
readkey;
END.
Program finish;
uses CRT;
Var x,xmin,n,j,xmax,f,dx,eps,q,c,k,m:real;
procedure input(var a:real);
begin
read(a);
end;
procedure arctg(x:real;var f:real);
begin
c:=1;
n:=0;
f:=0;
repeat
j:=-(2*n-1)/((2*n+1)*x*x);
c:=c*j;
f:=f+c;
until abs(f)<eps;
end;
procedure tab(xmin,xmax,q,x:real;var c:real);
begin
k:=0;
x:=xmin;
writeln ('x po Teyloru chislo chlenov arctan(x) ');
while x<=xmax do begin
arctg(x,f);
m:=arctan(x);
k:=k+1;
x:=x+dx;
writeln(x:2:2,' ', c:4:4{zn-e arctg(x)},' ', k:4:1,' ', m:4:4) ;
end;
end;
Begin
clrscr;
writeln('programma vichislyaet znachenie funkcii arctg(x) s pomoshu ryada Teylora');
write('vvedite xmin:');
input(xmin);
write('vvedite xmax:');
input(xmax);
write('vvedite step:');
input(dx);
write('vvedite tochnost:');
input(eps);
tab (xmin,xmax,q,x,c);
readkey;
END.
формулу разложения дай...
Замени свою процедуру arctg вот на это:
procedure arctg(x:real;var f:real);
var
j: real;
sign, n: integer;
begin
sign := -1;
n := 0;
f := Pi/2;
j := x;
repeat
j := j / (x*x);
c := j / (2*n + 1);
f := f + sign * c;
sign := - sign;
inc(n);
until abs© < eps;
end;
writeln(x:2:2,' ', F:4:4{zn-e arctg(x)},' ', k:4:1,' ', m:4:4) ;
...а еще половину глобальных переменных можно убрать.
у меня, в общем, так получилось:
Program finish;
uses CRT;
Var xmin,xmax,dx,eps:real;
procedure input(var a:real);
begin
readln(a);
end;
procedure arctg(x:real;var f:real;var n: integer);
var c,j: real;
begin
n:=0;
c:=-x;
f:=pi/2;
repeat
j:=1/((2*n+1)*c);
c:=-c*sqr(x);
n:=n+1;
f:=f+j;
until abs(j)<eps;
end;
procedure tab(xmin,xmax,dx:real);
var x,f: real;
k: integer;
begin
x:=xmin;
writeln ('x po Teyloru chislo chlenov arctan(x) ');
while x<=xmax do
begin
arctg(x,f,k);
writeln(x:2:2,' ', f:4:4{zn-e arctg(x)},' ', k:4,' ', arctan(x): 4 : 4) ;
x:=x+dx;
end;
end;
Begin
clrscr;
writeln('programma vichislyaet znachenie funkcii arctg(x) s pomoshu ryada Teylora');
write('vvedite xmin:');
input(xmin);
write('vvedite xmax:');
input(xmax);
write('vvedite step:');
input(dx);
write('vvedite tochnost:');
input(eps);
tab (xmin,xmax,dx);
readkey;
END.
мисс_граффити ,volvo ОГРОМЕННОЕ ВАМ СПА-СИ-БО!!! и "+" соответственно ))
т.е. я так понял, что у меня была с рекурентной формулой беда?
И с формулой, и выводил не совсем то.
уже 30 минут ищу кнопочку чтобы + поставить почему то рядом с вашим числом плюсов, картинки с изображением + и - не активны... наверно я еще оч мало на этом форуме.. недостаточно прав.
да, мало сообщений.
сегодня сдал!!! это была последня прога с прошлого семестра на зачет, штук 15 я сдал в январе-феврале, а с этой запарился))
Выкладываю итоговую версию задачи (вдруг кому пригодится)
Задание было таким:
Вычислить и вывести на экран в виде таблицы значения функции, заданной с помощью ряда Тейлора, на интервале от xmin до xmax с шагом dx с точностью e.
Каждая строка таблицы должна содержать значение аргумента, значение функции и количество просуммированных членов ряда. Операции ввода исходных данных, вычисления функции с помощью ряда Тейлора и табулирования функции реализовать в виде отдельных подпрограмм (процедур и функций).
Program finish;
uses CRT;
Var c,x,xmin,xmax,dx,eps,k,m,f:real;
procedure input(var a:real);
begin
read(a);
end;
procedure arctg(x:real;var f:real);
var
j: real;
sign, n: integer;
begin
n := 1;
c:=-1/x;
f := Pi/2+c;
repeat
c :=c*(-(2*n-1)/((2*n + 1)*(x*x)));
f := f + c;
inc(n);
until abs© < eps;
end;
procedure tab(xmax,x:real;var c:real);
var k,m:real;
begin
k:=0;
x:=xmin;
writeln ('x po Teyloru chislo chlenov arctan(x) ');
while x<=xmax do begin
arctg(x,f);
m:=arctan(x);
k:=k+1;
writeln(x:2:2,' ', f:6:6{zn-e arctg(x)},' ', k:4:1,' ', m:6:6) ;
x:=x+dx;
end;
end;
Begin
clrscr;
writeln('programma vichislyaet znachenie funkcii arctg(x) s pomoshu ryada Teylora');
write('vvedite xmin:');
input(xmin);
write('vvedite xmax:');
input(xmax);
write('vvedite step:');
input(dx);
write('vvedite tochnost:');
input(eps);
tab (xmax,x,c);
readkey;
END.
странную вещь ты сотворил....
зачем - я не поняла. я ж вроде выложила полную работающую программку, без лишних глобальных переменных... без НЕИСПОЛЬЗУЮЩИХСЯ переменных (а у тебя и такие есть).
ну взял бы подпрограмму arctg у volvo ... но брать описание переменных в его версии, а все остальное - в моей... оригинально.