尝试在 c++ 中将两个动态创建的矩阵(2d 向量)相乘

Trying to multiply two dynamically created matrices(2d vector's) together in c++

本文关键字:创建 2d 相乘 向量 动态 两个 c++      更新时间:2023-10-16

所以我要做的是将一个二维向量乘以另一个二维向量。

我来自Java,Python和C#,所以我在学习的过程中几乎在学习C++。

我有代码来生成向量并显示向量,但我似乎无法完成乘法部分。

v1 是另一个已生成的矩阵。

vector<vector<int> > v2 = getVector();
int n1 = v1[0].size();
int n2 = v2.size();
vector<int> a1(n2, 0);
vector<vector<int> > ans(n1, a1);
for (int i = 0; i < n1; i++) {
    for (int j = 0; j < n2; j++) {
        for (int k = 0; k < 10; k++) {
            // same as z[i][j] = z[i][j] + x[i][k] * y[k][j];
            ans[i][j] += v1[i][k] * v2[k][j];
        }
    }
}
displayVector(ans);

我对自己哪里出错的猜测是在最内层的循环中。我不知道该用什么来代替我现在拥有的那 10 个。

乘以矩阵时,左侧矩阵的列数必须等于右侧矩阵的行数。您需要检查这是否为真,并将该公共数字用于k变量的大小:

int nCommon = v1.size();
assert(v2[0].size() == nCommon);
for (int i = 0; i < n1; i++) {
    for (int j = 0; j < n2; j++) {
        for (int k = 0; k < nCommon ; k++) {
            ans[i][j] += v1[i][k] * v2[k][j];
        }
    }
}

对于你的内部循环,你应该做这样的事情

            ans[i][j] = 0;
            for (int k = 0; k < n2; k++) {               
                ans[i][j] += v1[i][k] * v2[k][j];
            }

我不知道10从何而来。