Технический форум
Вернуться   Технический форум > Программирование > Форум программистов > Помощь студентам


Ответ
 
Опции темы Опции просмотра
Старый 05.02.2015, 15:42   #1 (permalink)
Bugavix
Новичок
 
Регистрация: 05.02.2015
Сообщений: 4
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию Работа с функциями в паскале

В прикреплённом файле задача.Решаю, задаю две функции, а с третьей не знаю как увязать.
Вложения
Тип файла: docx Zadacha.docx (18.8 Кб, 121 просмотров)
Bugavix вне форума   Ответить с цитированием

Старый 05.02.2015, 15:42
Helpmaster
Member
 
Аватар для Helpmaster
 
Регистрация: 08.03.2016
Сообщений: 0

Так же вы можете поискать решение проблемы в аналогичных темах

Помогите с процедурами и функциями
Работа с массивами в Паскале
PocketBook SURFpad - ридер с мультимедийными функциями
Помогите, пожалуйста, с подпрограммами и функциями
Работа в Паскале
Помогите с задачей в паскале, работа с файлами

Старый 05.02.2015, 15:50   #2 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Да ладно, тоже мне - проблема века! Сейчас нарисую. Формула, правда, не отобразилась:
sp_1.jpg
ну да неважно...
P.S. А, нет - вроде всё отображается. Я думал, там еще формула угла.
Vladimir_S вне форума   Ответить с цитированием
Старый 05.02.2015, 16:33   #3 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Вот, получите:
Код:
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.
Vladimir_S вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
Ответ

Опции темы
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.
Trackbacks are Вкл.
Pingbacks are Вкл.
Refbacks are Выкл.




Часовой пояс GMT +4, время: 13:01.

Powered by vBulletin® Version 6.2.5.
Copyright ©2000 - 2014, Jelsoft Enterprises Ltd.