矩阵乘法与向量- c++
Matrix multiplication with vectors - C++
我正在制作一个程序,可以乘矩阵的用户定义的大小。我用向量来存储矩阵中的值。
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()成员函数。
那么就只需要手工进行乘法运算了,如下所示(其中还包括一些伪代码)。
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么