Помощь - Поиск - Пользователи - Календарь
Полная версия: Помогите разобраться с переменными в 2-х процедурах.
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Jack K.
Всем доброго времени суток! Вот возникла проблемка... Немогу связать 2 процедуры для подсчета arctg(x) через ряд Тейлора... проблема в локальных/глобальных переменных или еще передачу по ссылке или по значению где нить напутал 100%... я в тупике. Пжжалста помогите, кто нить!!! mega_chok.gif
Вот так вот я ее написал:

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.

Jack K.
Цитата(Jack K. @ 10.05.2007 22:26) *

Всем доброго времени суток! Вот возникла проблемка... Немогу связать 2 процедуры для подсчета arctg(x) через ряд Тейлора... проблема в локальных/глобальных переменных или еще передачу по ссылке или по значению где нить напутал 100%... я в тупике. Пжжалста помогите, кто нить!!! mega_chok.gif
Вот так вот я ее написал:

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.



з.ы. подправил j в первой процедуре... там "-" на "+" исправил.. аааа, очень надо!! завтра сдавать...
мисс_граффити
формулу разложения дай...
Jack K.
Цитата(мисс_граффити @ 18.06.2007 22:33) *

формулу разложения дай...


Вотъ
volvo
Замени свою процедуру 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;



А в процедуре Tab печатай не С, а F:
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.
Jack K.
мисс_граффити ,volvo ОГРОМЕННОЕ ВАМ СПА-СИ-БО!!! good.gif и "+" соответственно ))

т.е. я так понял, что у меня была с рекурентной формулой беда?
мисс_граффити
И с формулой, и выводил не совсем то.
Jack K.
blink.gif уже 30 минут ищу кнопочку чтобы + поставить wacko.gif почему то рядом с вашим числом плюсов, картинки с изображением + и - не активны... наверно я еще оч мало на этом форуме.. недостаточно прав.
мисс_граффити
да, мало сообщений.
Michael_Rybak
Цитата
уже 30 минут ищу кнопочку чтобы + поставить
почему то рядом с вашим числом плюсов, картинки с изображением + и - не активны... наверно я еще оч мало на этом форуме.. недостаточно прав.


Увеличил обоим.
Jack K.
сегодня сдал!!! это была последня прога с прошлого семестра на зачет, штук 15 я сдал в январе-феврале, а с этой запарился))

Выкладываю итоговую версию задачи smile.gif (вдруг кому пригодится)
Задание было таким:
Вычислить и вывести на экран в виде таблицы значения функции, заданной с помощью ряда Тейлора, на интервале от 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.


p.s. Michael_Rybak, спсиб за плюсы smile.gif
мисс_граффити
странную вещь ты сотворил....
зачем - я не поняла. я ж вроде выложила полную работающую программку, без лишних глобальных переменных... без НЕИСПОЛЬЗУЮЩИХСЯ переменных (а у тебя и такие есть).
ну взял бы подпрограмму arctg у volvo ... но брать описание переменных в его версии, а все остальное - в моей... оригинально.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.