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

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

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

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

Задача на действия над матрицами Паскаль ABC

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

Ekama

Banned
Регистрация
20 Ноя 2012
Сообщения
8
Реакции
0
Баллы
0
Задача на действия над матрицами Паскаль ABC

Выполнить действия над правильными матрицами A[n,n] и B[n,n]: (2,5A+b^2)(A-B^2)
 
Выполнить действия над правильными матрицами A[n,n] и B[n,n]: (2,5A+b^2)(A-B^2)
Так, ну вот Вам программа. Сразу оговорюсь: сделана и оттестирована в среде Free Pascal, работает (см. скрин), а за возможные глюки псевдопаскаля АВС я не отвечаю - у меня подобной дряни не водится.
Код:
Const
 N=5;

Type
 Matrix=Array[1..N,1..N] of real;

Var
 A,B,C:Matrix;
 i,j:Integer;

Function Mult(M1:Matrix;Q:real):Matrix;
var i,j:Integer;
begin
 for i:=1 to N do
  for j:=1 to N do
   Mult[i,j]:=M1[i,j]*Q;
end;

Function Sum(M1,M2:Matrix):Matrix;
var i,j:Integer;
begin
 for i:=1 to N do
  for j:=1 to N do
   Sum[i,j]:=M1[i,j]+M2[i,j];
end;

Function Prod(M1,M2:Matrix):Matrix;
var
 i,j,k:Integer;
 Prd:real;
begin
 for i:=1 to N do
  for j:=1 to N do
   begin
    Prd:=0;
    for k:=1 to N do
     Prd:=Prd+M1[i,k]*M2[k,j];
    Prod[i,j]:=Prd;
   end;
end;

Begin 
 Randomize;
 For i:=1 to N do
  For j:=1 to N do
   begin
    A[i,j]:=(0.8-Random)*10;
    B[i,j]:=(0.2-Random)*10;
   end;
 Writeln('Matrix A:                               Matrix B:');
 For i:=1 to N do
  begin
   For j:=1 to N do Write(A[i,j]:6:1);
   Write('          ');
   For j:=1 to N do Write(B[i,j]:6:1);
   Writeln;
  end;
 Writeln;
 Writeln('Result:');
 C:=Prod(Sum(Mult(A,2.5),Prod(B,B)),Sum(A,Mult(Prod(B,B),-1)));
 For i:=1 to N do
  begin
   For j:=1 to N do Write(C[i,j]:12:1);
   Writeln;
  end;
 Readln;
End.
 

Вложения

  • Ekama.webp
    Ekama.webp
    21.9 KB · Просмотры: 119
Назад
Сверху