Построить график функции - Turbo Pascal (29417)

Узнай цену своей работы

Формулировка задачи:

Построить график функции y=x^3*tg(x) на отрезке [a,b] a,b ввести с клавиатуры

Решение задачи: «Построить график функции»

textual
Листинг программы
  1. uses graph,crt;
  2. function F(x:real):real;
  3. begin
  4. F:=x*x*x*sin(x)/cos(x);
  5. end;
  6.  
  7. var a,b,mx,my,x:real;
  8.     x0,y0,n,i:integer;
  9.     s:string;
  10. begin
  11. clrscr;
  12. {введем a,b так чтобы получить более-менее приличный график}
  13. repeat
  14. write('-7<=a<=-3 a=');
  15. readln(a);
  16. until(a>=-7)and(a<=-3);
  17. repeat
  18. write('3<=b<=7 b=');
  19. readln(b);
  20. until(b>=3)and(b<=7);
  21. initgraph(x0,y0,'');
  22. x0:=round(-a*(getmaxX-30)/(b-a));
  23. mx:=(x0-30)/-a;{масштаб по Х}
  24. y0:=getmaxY div 2;
  25. my:=(y0-30)/50;{примем макс по оси Y=50, он бесконечен}
  26. line(0,y0,getmaxX,y0);{оси}
  27. line(x0,0,x0,getmaxY);
  28. n:=5;
  29. if trunc(-a)+1>n then n:=trunc(-a)+1;
  30. if trunc(b)+1>n then n:=trunc(b)+1;
  31. for i:=1 to n do{максимальное количество засечек в одну сторону}
  32.  begin
  33.   line(x0-3,y0-round(i*my*10),x0+3,y0-round(i*my*10));{засечки на оси У}
  34.   line(x0-3,y0+round(i*my*10),x0+3,y0+round(i*my*10));
  35.   {подпись оси У}
  36.   str(i*10,s);
  37.   outtextXY(x0-30,y0-round(i*my*10),s);{соответственно засечкам}
  38.   outtextXY(x0-35,y0+round(i*my*10),'-'+s);
  39.   line(x0-round(i*mx),y0-3,x0-round(i*mx),y0+3); {засечки на оси Х}
  40.   line(x0+round(i*mx),y0-3,x0+round(i*mx),y0+3);
  41.   {подпись оси X}
  42.   str(i,s);
  43.   outtextXY(x0-round(i*mx),y0+10,s);{соответственно засечкам}
  44.   outtextXY(x0+round(i*mx),y0+10,+s);
  45.  end;
  46. {центр}
  47. outtextXY(x0+5,y0+10,'0');
  48. {подписи концов осей}
  49. outtextXY(getmaxX-10,y0-10,'X');
  50. outtextXY(x0+5,10, 'Y');
  51. {график}
  52. x:=a;
  53. while x<=b do
  54.  begin
  55.   if abs(cos(x))>0.01 then putpixel(x0+round(x*mx),y0-round(F(x)*my),12);
  56.   x:=x+0.0001;
  57.  end;
  58. {ассимтоты}
  59. setcolor(10);
  60. setlinestyle(3,0,1);
  61. for i:=1 to 2 do
  62.  begin
  63.   line(x0+round((2*i-1)*pi/2*mx),0,x0+round((2*i-1)*pi/2*mx),2*y0);
  64.   line(x0-round((2*i-1)*pi/2*mx),0,x0-round((2*i-1)*pi/2*mx),2*y0);
  65.  end;
  66. {название}
  67. setcolor(12);
  68. outtextXY(60,10,'y=x^3*tg(x)');
  69. readln
  70. end.

Объяснение кода листинга программы

  1. В первой строке кода используется библиотека graph, которая отвечает за отображение графика, и функция initgraph, которая инициализирует график.
  2. Далее определяются переменные a, b, mx, my, x и y, которые будут использоваться для построения графика.
  3. Затем в цикле читаются значения a и b с помощью функции readln до тех пор, пока они удовлетворяют определенным условиям (a и b больше или равны -7 и меньше или равны 3 соответственно).
  4. После этого вызывается функция initgraph с начальными координатами x0, y0, которые определяются как среднее значение a и b.
  5. Далее определяется масштаб по осям X и Y. Ось Y масштабируется так, чтобы максимальное значение было равно 50, а ось X масштабируется так, чтобы она была пропорциональна масштабу оси Y.
  6. Затем начинается цикл, который проходит по всем точкам на графике. Для каждой точки вычисляются координаты x и y с помощью формулы из функции F, которая зависит от значения x.
  7. В цикле также выводятся подписи осей и оси Y, а также строки с номерами засечек.
  8. После завершения цикла выводятся ассимптоты для оси X.
  9. Затем выводится название графика с помощью функции outtextXY.
  10. Наконец, вызывается функция readln для завершения ввода данных.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

9   голосов , оценка 4 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут