Программа рисует узор (см. вложение), состоящий из 20 эллипсов, каждый из которых повёрнут на 9 градусов относительно предыдущего. Угол поворота задаётся переменной а, которая изменяется от 0 до 180 (так как 20*9=180). Cos(a) и Sin(a) задают положение эллипса.
Каждый эллипс рисуется с помощью 6280 точек (цикл по k) командой PutPixel? начиная с крайней левой точки эллипса. Cos(t) и Sin(t) задают отклонение каждой точки от "центра" эллипса.
PS Кстати, в программе есть ошибка - цвет надо задавать как "clWhite", a не "White" - хотя задавать белый вобще нет смысла - его не будет видно :)
Uses GraphABC;
begin
line(300,50,300,450);
line(150,250,550,250);
line(300,50,295,60);
line(300,50,305,60);
line(550,250,540,245);
line(550,250,540,255);
<span>end.</span>
<em>// PascalABC.NET 3.3, сборка 1579 от 18.11.2017</em>
<em>// Внимание! Если программа не работает, обновите версию!</em>
begin
var (m,n):=ReadInteger2('Количество строк и столбцов в матрице:');
Writeln('*** Исходная матрица [',m,',',n,'] ***');
var a:=MatrRandom(m,n,-50,50);
a.Println(4); Writeln(4*a.ColCount*'-');
var s:=a.Rows.SelectMany(x->x);
var max:=s.Max;
Writeln('Максимум ',max, ' встречается ',
s.Where(x->x=max).Count,' раз(а)')
end.
<u>Пример</u>
Количество строк и столбцов в матрице: 6 11
*** Исходная матрица [6,11] ***
15 19 26 0 -21 -42 8 -9 -7 21 19
-7 -49 23 -10 8 -9 -50 -31 8 -49 -36
-42 -45 -49 -11 3 -45 -20 45 -29 39 13
9 45 -19 9 -31 -38 29 27 39 13 36
-47 28 44 8 -22 28 7 -25 -3 -9 39
1 11 20 -1 40 5 2 -40 -2 -1 30
--------------------------------------------
Максимум 45 встречается 2 раз(а)
var c,m,t1,t2,q: integer;
begin
write('Введите c ');
readln(c);
write('Введите m ');
readln(m);
write('Введите t1 ');
readln(t1);
write('Введите t2 ');
readln(t2);
q:=c*m*(t2-t1);
writeln('количества теплоты ',q);
Я не знаю но может вот это поможет?