with Ada.Text_IO ; use Ada.Text_IO ;
with Ada.Integer_Text_IO ; use Ada.Integer_Text_IO ;
procedure Q5L is
-- Definindo tipos para as matrizes
type Matrix is array ( 1 .. 10 , 1 .. 10 ) of Integer; -- Máximo de 10x10
A, B, C : Matrix; -- Matrizes A, B e C
M, N, P, Q : Integer; -- Dimensões das matrizes
begin
-- Entrada da matriz A
Put( "Digite o número de linhas da matriz A (m): " ) ;
Get( M) ;
Put( "Digite o número de colunas da matriz A (n): " ) ;
Get( N) ;
Put_Line( "Digite os elementos da matriz A:" ) ;
for I in 1 .. M loop
for J in 1 .. N loop
Put( "Elemento (" & Integer'Image( I) & ", " & Integer'Image( J) & "): " ) ;
Get( A( I, J) ) ;
end loop ;
end loop ;
-- Entrada da matriz B
Put( "Digite o número de linhas da matriz B (p): " ) ;
Get( P) ;
Put( "Digite o número de colunas da matriz B (q): " ) ;
Get( Q) ;
Put_Line( "Digite os elementos da matriz B:" ) ;
for I in 1 .. P loop
for J in 1 .. Q loop
Put( "Elemento (" & Integer'Image( I) & ", " & Integer'Image( J) & "): " ) ;
Get( B( I, J) ) ;
end loop ;
end loop ;
-- Inicializando a matriz C com zeros
for I in 1 .. M loop
for J in 1 .. Q loop
C( I, J) := 0 ;
end loop ;
end loop ;
-- Calculando a matriz C = A * B
for I in 1 .. M loop
for J in 1 .. Q loop
for K in 1 .. N loop
-- Considerando que elementos fora do tamanho da matriz são 0
C( I, J) := C( I, J) + A( I, K) * ( if K <= P then B( K, J) else 0 ) ;
end loop ;
end loop ;
end loop ;
-- Exibindo a matriz C
Put_Line( "A matriz C = A * B é:" ) ;
for I in 1 .. M loop
for J in 1 .. Q loop
Put( Integer'Image( C( I, J) ) & " " ) ;
end loop ;
New_Line; -- Nova linha após cada linha da matriz
end loop ;
end Q5L;
d2l0aCBBZGEuVGV4dF9JTzsgdXNlIEFkYS5UZXh0X0lPOwp3aXRoIEFkYS5JbnRlZ2VyX1RleHRfSU87IHVzZSBBZGEuSW50ZWdlcl9UZXh0X0lPOwoKcHJvY2VkdXJlIFE1TCBpcwogICAgLS0gRGVmaW5pbmRvIHRpcG9zIHBhcmEgYXMgbWF0cml6ZXMKICAgIHR5cGUgTWF0cml4IGlzIGFycmF5ICgxIC4uIDEwLCAxIC4uIDEwKSBvZiBJbnRlZ2VyOyAgLS0gTcOheGltbyBkZSAxMHgxMAogICAgQSwgQiwgQyA6IE1hdHJpeDsgIC0tIE1hdHJpemVzIEEsIEIgZSBDCiAgICBNLCBOLCBQLCBRIDogSW50ZWdlcjsgIC0tIERpbWVuc8O1ZXMgZGFzIG1hdHJpemVzCgpiZWdpbgogICAgLS0gRW50cmFkYSBkYSBtYXRyaXogQQogICAgUHV0KCJEaWdpdGUgbyBuw7ptZXJvIGRlIGxpbmhhcyBkYSBtYXRyaXogQSAobSk6ICIpOwogICAgR2V0KE0pOwogICAgUHV0KCJEaWdpdGUgbyBuw7ptZXJvIGRlIGNvbHVuYXMgZGEgbWF0cml6IEEgKG4pOiAiKTsKICAgIEdldChOKTsKCiAgICBQdXRfTGluZSgiRGlnaXRlIG9zIGVsZW1lbnRvcyBkYSBtYXRyaXogQToiKTsKICAgIGZvciBJIGluIDEgLi4gTSBsb29wCiAgICAgICAgZm9yIEogaW4gMSAuLiBOIGxvb3AKICAgICAgICAgICAgUHV0KCJFbGVtZW50byAoIiAmIEludGVnZXInSW1hZ2UoSSkgJiAiLCAiICYgSW50ZWdlcidJbWFnZShKKSAmICIpOiAiKTsKICAgICAgICAgICAgR2V0KEEoSSwgSikpOwogICAgICAgIGVuZCBsb29wOwogICAgZW5kIGxvb3A7CgogICAgLS0gRW50cmFkYSBkYSBtYXRyaXogQgogICAgUHV0KCJEaWdpdGUgbyBuw7ptZXJvIGRlIGxpbmhhcyBkYSBtYXRyaXogQiAocCk6ICIpOwogICAgR2V0KFApOwogICAgUHV0KCJEaWdpdGUgbyBuw7ptZXJvIGRlIGNvbHVuYXMgZGEgbWF0cml6IEIgKHEpOiAiKTsKICAgIEdldChRKTsKCiAgICBQdXRfTGluZSgiRGlnaXRlIG9zIGVsZW1lbnRvcyBkYSBtYXRyaXogQjoiKTsKICAgIGZvciBJIGluIDEgLi4gUCBsb29wCiAgICAgICAgZm9yIEogaW4gMSAuLiBRIGxvb3AKICAgICAgICAgICAgUHV0KCJFbGVtZW50byAoIiAmIEludGVnZXInSW1hZ2UoSSkgJiAiLCAiICYgSW50ZWdlcidJbWFnZShKKSAmICIpOiAiKTsKICAgICAgICAgICAgR2V0KEIoSSwgSikpOwogICAgICAgIGVuZCBsb29wOwogICAgZW5kIGxvb3A7CgogICAgLS0gSW5pY2lhbGl6YW5kbyBhIG1hdHJpeiBDIGNvbSB6ZXJvcwogICAgZm9yIEkgaW4gMSAuLiBNIGxvb3AKICAgICAgICBmb3IgSiBpbiAxIC4uIFEgbG9vcAogICAgICAgICAgICBDKEksIEopIDo9IDA7CiAgICAgICAgZW5kIGxvb3A7CiAgICBlbmQgbG9vcDsKCiAgICAtLSBDYWxjdWxhbmRvIGEgbWF0cml6IEMgPSBBICogQgogICAgZm9yIEkgaW4gMSAuLiBNIGxvb3AKICAgICAgICBmb3IgSiBpbiAxIC4uIFEgbG9vcAogICAgICAgICAgICBmb3IgSyBpbiAxIC4uIE4gbG9vcAogICAgICAgICAgICAgICAgLS0gQ29uc2lkZXJhbmRvIHF1ZSBlbGVtZW50b3MgZm9yYSBkbyB0YW1hbmhvIGRhIG1hdHJpeiBzw6NvIDAKICAgICAgICAgICAgICAgIEMoSSwgSikgOj0gQyhJLCBKKSArIEEoSSwgSykgKiAoaWYgSyA8PSBQIHRoZW4gQihLLCBKKSBlbHNlIDApOwogICAgICAgICAgICBlbmQgbG9vcDsKICAgICAgICBlbmQgbG9vcDsKICAgIGVuZCBsb29wOwoKICAgIC0tIEV4aWJpbmRvIGEgbWF0cml6IEMKICAgIFB1dF9MaW5lKCJBIG1hdHJpeiBDID0gQSAqIEIgw6k6Iik7CiAgICBmb3IgSSBpbiAxIC4uIE0gbG9vcAogICAgICAgIGZvciBKIGluIDEgLi4gUSBsb29wCiAgICAgICAgICAgIFB1dChJbnRlZ2VyJ0ltYWdlKEMoSSwgSikpICYgIiAiKTsKICAgICAgICBlbmQgbG9vcDsKICAgICAgICBOZXdfTGluZTsgIC0tIE5vdmEgbGluaGEgYXDDs3MgY2FkYSBsaW5oYSBkYSBtYXRyaXoKICAgIGVuZCBsb29wOwplbmQgUTVMOwo=