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

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

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

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

Работа с функциями в паскале

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

Bugavix

Ученик
Регистрация
5 Фев 2015
Сообщения
4
Реакции
0
Баллы
0
Работа с функциями в паскале

В прикреплённом файле задача.Решаю, задаю две функции, а с третьей не знаю как увязать.
 

Вложения

Да ладно, тоже мне - проблема века! Сейчас нарисую. Формула, правда, не отобразилась:
SP_1.webp
ну да неважно...
P.S. А, нет - вроде всё отображается. Я думал, там еще формула угла.
 
Вот, получите:
Код:
Type
 Vector=Array[1..3] of real;

Var
 A,B:Vector;
 i:Byte;

Function RadGr(X:Real):Real;
begin
 RadGr:=(X/Pi)*180;
end;

Function ArcCos(X:Real):Real;
begin
 if X=1 then ArcCos:=0 else
 if X=-1 then ArcCos:=Pi else
  ArcCos:=(Pi/2)-ArcTan(X/Sqrt(1-X*X));
end;

Function Norm(T:Vector):Real;
begin
 Norm:=Sqrt(Sqr(T[1])+Sqr(T[2])+Sqr(T[3]));
end;

Function Scal_Prod(T1,T2:Vector):Real;
var
 k:byte;
 S:Real;
begin
 S:=0;
 for k:=1 to 3 do S:=S+T1[k]*T2[k];
 Scal_Prod:=S;
end;

Function Angle(T1,T2:Vector):Real;
begin
 Angle:=RadGr(ArcCos(Scal_Prod(T1,T2)/(Norm(T1)*Norm(T2))));
end;

Begin
 Randomize;
 for i:=1 to 3 do
  begin
   A[i]:=(Random-0.5)*10;
   B[i]:=(Random-0.5)*10;
  end;
 Writeln('Vector A:');
 Writeln('(',A[1]:6:3,',',A[2]:7:3,',',A[3]:7:3,')');
 Writeln('Vector B:');
 Writeln('(',B[1]:6:3,',',B[2]:7:3,',',B[3]:7:3,')');
 Writeln('Angle: ',Angle(A,B):0:3,' deg.');
 Readln
End.
 
Назад
Сверху