IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> график функции в турбо паскале
сообщение
Сообщение #1


Гость






<...>
Надо построить график функции котангенса. График должен отображать результаты расчетов, которые записаны на диске. Масштаб разметки осей кординат должен отвечать реальным результатам расчетов. Основную часть экрана должны занимать те четверти, в которых находится график.

Сообщение отредактировано: volvo -
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
сообщение
Сообщение #2


Гость






Ну, вот тебе набросок, попробуй разобраться, как он работает... Разметку осей сделай сама.
uses Graph;

const
Every = 2;

var
Table: array[1 .. 2, 1 .. 49 * Every] of real;

function max(a, b: real): real;
begin
max := a; if a < b then max := b;
end;

function Ctg(x: real): real;
begin
if Abs(x) < 0.0001 then Ctg := 1000
else Ctg := Cos(x) / Sin(x);
end;

var
grDriver, grMode, ErrCode: Integer;
i: integer;
x, _max, _min: real;
scale_x, scale_y: real;

f: text;

begin
assign(f, 'cotan.txt');
rewrite(f);

_max := -maxint; _min := maxint;
for i := 1 to 49 * Every do
begin
Table[1, i] := (i - 24 * Every) * Pi / (50 * Every);
Table[2, i] := Ctg(i * Pi / (50 * Every));

if _max < Table[2, i] then _max := Table[2, i];
if _min > Table[2, i] then _min := Table[2, i];
writeln(f, 'x = ', Table[1, i]:10:4, ' ctg(x) = ', Table[2, i]:10:4)
end;
close(f);

grDriver := Detect;
InitGraph(grDriver, grMode,'');
ErrCode := GraphResult;
if ErrCode <> grOk then begin
Writeln('Graphics error:', GraphErrorMsg(ErrCode));
ReadLn; Halt(101)
end;

setcolor(red);
line(0, getmaxy div 2, getmaxx, getmaxy div 2);
line(getmaxx div 2, 0, getmaxx div 2, getmaxy);

scale_y := (getmaxy / 2) / max(abs(_min), abs(_max));
scale_x := getmaxx / (3 * 49 * Every * Pi / (50 * Every));

for i := 1 to 49 * Every do
begin
putpixel((getmaxx div 2) + trunc(Table[1, i] * scale_x),
(getmaxy div 2) - trunc(Table[2, i] * scale_y),
white);
end;
readln;

CloseGraph;
end.

Если хочешь увеличить плотность точек на графике, увеличивай константу Every (можно попробовать увеличить до 5 .. 10). В файле "COTAN.TXT" содержатся результаты вычисления котангенса...
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 12.09.2025 22:33
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name