Помощь - Поиск - Пользователи - Календарь
Полная версия: Помогите разобраться с переменными в 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(c) < 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(c) < 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 ... но брать описание переменных в его версии, а все остальное - в моей... оригинально.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.