函数apply_all应该将array2 (of size2)的所有元素多到array1 (of size1)的所有元素,并将它们存储在动态创建的向量上(大小为1×2),编译器提到这一行以避免错误: array3.at(i)=array1.at(k)*array2.at(j);
#include <iostream>
#include <vector>
using namespace std;
vector<int> *apply_all(vector<int>&array1,size_t &size1,vector<int>&array2,size_t &size2)
{
vector<int> *array3{nullptr};
array3=new vector<int>(size1*size2); //heap memory allocated using vectors
size_t i{0};
for (size_t j=0;j<size2;j++){
for (size_t k=0;k<size1;k++){
array3.at(i)=array1.at(k)*array2.at(j);
i++;
}
}
return array3;
}发布于 2020-09-03 13:14:51
分配向量简直是疯了。使用向量的大部分优点(比如不必手动管理内存)瞬间就消失了。在堆栈上创建向量,如下所示
vector<int> apply_all(vector<int>&array1,size_t &size1,vector<int>&array2,size_t &size2)
{
vector<int> array3(size1*size2);
...
return array3;
}这也修复了您询问的错误。
向量从堆中分配内存,但不需要从堆中分配向量本身的。
https://stackoverflow.com/questions/63724203
复制相似问题