Нахождение произведения матриц - Turbo Pascal

Формулировка задачи:

Даны две матрицы А(nxn) и B(nxn). Написать программу нахождения произведения этих матриц D = A*B.

Код к задаче: «Нахождение произведения матриц - Turbo Pascal»

textual
uses crt;
const nmax=20;
var A,B,U:array[1..nmax,1..nmax]of integer;
    ka,la,kb,lb,i,j,r:integer;
begin
clrscr;
randomize;
writeln('Razmery matricy A:');
repeat
write('Kolichestvo strok ka=');readln(ka);
until (ka>0)and(ka<=nmax);
repeat
write('Kolichestvo stolbcov la=');readln(la);
until (la>0)and(la<=nmax);
writeln('Razmery matricy B:');
repeat
write('Kolichestvo strok kb=');readln(kb);
until (kb>0)and(kb<=nmax);
repeat
write('Kolichestvo stolbcov lb=');readln(lb);
until (lb>0)and(lb<=nmax)and(lb=ka); 
writeln('Matrica A:');
for i:=1 to ka do
   begin
     for j:=1 to la do
       begin
         A[i,j]:=random(9)+1;
         write(A[i,j]:3);
       end;
     writeln;
   end;
readln;
writeln('Matrica B:');
for i:=1 to kb do
   begin
     for j:=1 to lb do
       begin
         B[i,j]:=random(9)+1;
         write(B[i,j]:3);
       end;
     writeln;
   end;
readln;
for r:=1 to ka do
for j:=1 to lb do
   begin
     U[r,j]:=0;
     for i:=1 to la do
       begin
         U[r,j]:=U[r,j]+A[r,i]*B[i,j];
       end;
   end;
writeln('Matrica U=A*B:');
for i:=1 to ka do
    begin
      for j:=1 to lb do
      write(U[i,j]:5);
      writeln;
    end;
readln;
end.

7   голосов, оценка 4.000 из 5


СОХРАНИТЬ ССЫЛКУ