【C++】矩陣乘法

for(int i=0; i<n1; i++){
    for(int j=0; j<m2; j++){
        c[i][j] = 0; //在外處理也可以
        for(int k=0; k<n2; k++){
            c[i][j] += a[i][k]*b[k][j]; //核心
        }
    }
}
#include <iostream>
using namespace std;
int main(){
    int n1, m1, n2, m2;
    cin >> n1 >> m1;
    int a[n1][m1];
    for(int i=0; i<n1; i++)
        for(int j=0; j<m1; j++)
            cin >> a[i][j];
    
    cin >> n2 >> m2;
    int b[n2][m2];
    for(int i=0; i<n2; i++)
        for(int j=0; j<m2; j++)
            cin >> b[i][j];
        
    int c[n1][m2];
    for(int i=0; i<n1; i++){
        for(int j=0; j<m2; j++){
            c[i][j] = 0;
            for(int k=0; k<n2; k++){
                c[i][j] += a[i][k]*b[k][j];
            }
        }
    }
    for(int i=0; i<n1; i++){
        for(int j=0; j<m2; j++)
            cout << c[i][j] << ' ';
        cout << '\n';
    }
}
發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *