矩阵乘法与向量- c++

Matrix multiplication with vectors - C++

本文关键字:向量 c++      更新时间:2023-10-16

我正在制作一个程序,可以乘矩阵的用户定义的大小。我用向量来存储矩阵中的值。

void Multiply(vector<float> A,vector<float> B,int rA, int cA,int rB,int cB)
{
system(CLEARSCREEN);
vector<float> C; // The resulting matrix
int sizeA=rA*cA;
int sizeB=rB*cB;
int sizeC=rA*cB;
int lrA=sizeA-1;
int lrB=sizeB-1;
int writeHead=0;
A.resize(sizeA);
B.resize(sizeB);
C.resize(sizeC);
demoDisplay(rA,rB,cA,cB,lrA,lrB,sizeA,sizeB);
for(;writeHead<=lrA; writeHead++)
{
    cout << "Please enter a value for "" << alphabet[writeHead] << "" in MATRIX A.n";
    cin >> A[writeHead];
}
cout << "n";
writeHead=0;
for (;writeHead<=lrB; writeHead++)
{
    cout << "Please enter a value for "" << alphabet[writeHead] << "" in MATRIX B.n";
    cin >> B[writeHead];
}
cout << "nn";
displayMatrices(A,B,rA,rB,cA,cB,lrA,lrB,sizeA,sizeB);
for (int colRead=0; colRead<=cA; colRead++) {
    // somehow iterate through each element of the vector?
}   
}

我对c++比较陌生,所以我不太确定如何做这两个矩阵的实际乘法。如果有人能帮忙,那就太好了。

也许您被vector容器的名称误导了,它暗示了一些数学用途。向量模板不提供任何函数来相乘矩阵,甚至相乘向量。在这种情况下,向量只提供了一个存储矩阵的容器。显然,你以某种线性化的方式存储矩阵,这将使后面的乘法更加复杂。

请务必阅读http://www.cplusplus.com/reference/stl/vector/

此外,你并不真的想遍历vector,因为如果是这种情况,你可以直接使用其他容器。你想要随机访问,手工将列和行相乘。为此,您可以使用[]-操作符]或at()成员函数。

那么就只需要手工进行乘法运算了,如下所示(其中还包括一些伪代码)。