• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Подскажите с задачей

  • Автор темы Автор темы azamatom
  • Дата начала Дата начала

azamatom

Ученик
Регистрация
3 Июн 2010
Сообщения
2
Реакции
0
Баллы
0
Подскажите с задачей

Построить окружность радиуса R c центром в начале координат по заданному параметрическому представлению X=R*Cos(t); Y=R*Sin(t) 0 <= t < 2*Pi.
правильно ли я вообще начал?
procedure
var
x,y,r,t:real;
begin
r:=StrToFloat(Edit1.text);//радиус
If t>=0 and (t<(2*pi)) then
x:=r*cos(t);
y:=r*sin(t);

with Image1.Canvas do
ellipse(FloatToStrF(x,ffGeneral,6,3),y,0,0);
 
Подскажите пожалуйста как правильно написать решение условий:
a>0, b>0. или b>=2a, a<b<2a, a>b. Сколько пытался, только не пойму куда можно вывести решение.
Улитка Паскаля :
x = a*cos(t)2 +b*cos(t), y = a*cos(t)*sin(t) + b*sin(t),
a>0, b>0, t  [0,2pi). Рассмотреть случаи, когда b>=2a, a<b<2a, a>b.
Код:
procedure TForm1.Button4Click(Sender: TObject);
var
 l,bb: integer;  
 w: integer;   
 x0,y0: integer; 
 g: Integer;
 t: Real;
 x, y: Real;
 a,b:integer;
 st:string;
begin
  l := 150;  
  bb := Form1.ClientHeight-270;  
  w := Form1.Width-200;        
  x0 :=l;
  y0:= bb - Abs(Round(bb / 2));
  a:=StrToInt(Edit4.Text);
  b:=StrToInt(Edit5.Text);
With Image1.Canvas do
begin
  MoveTo(l, 20); LineTo(l, bb-20);
  Font.Size := 14;
  MoveTo(x0, y0); LineTo(x0 + w - l, y0);
  MoveTo(x0, y0); LineTo(x0 - w + l, y0);
  Font.Size := 14;
  TextOut(l + w - l - 20, y0 + 20, 'x');
  MoveTo(150,0);LineTo(150,400);
  Textout(152,165,'0');//öåíòð
  Textout(270,165,'0');
  Textout(20,165,'PI');
  Textout(110,20,'PI/2');
  Textout(95,270,'3*PI/2');
  Pen.Color := clRed;
For g := 0 to 360 do
begin
  t := g * Pi / 180;
If (a>0) and (b>0) then
  x := x0 + a * sqr(cos(t)) + b * cos(t);
  y := y0 + a * cos(t) * sin(t) + b * sin(t);
If g = 0 then
  MoveTo(Round(x), Round(y))
else
  LineTo(Round(x), Round(y));
end;
begin
If (a>b) then
  x := x0 + a * sqr(cos(t)) + b * cos(t);
  y := y0 + a * cos(t) * sin(t) + b * sin(t);
  Showmessage('x='+floattostrf(x,fffixed,9,2));
end;
end;
end;
end.
 
Последнее редактирование:
Назад
Сверху