我需要创建一个将2个数组相乘的函数,并将结果放入第三个数组中,我将使用另一个“打印函数”进行打印。 所以如果我输入array11:5,10,20;和array22:1,2;我应该得到这个结果: result_array:5,10,10,20,20,40。因此,第一个数组中的每个元素与第二个数组中的每个元素相乘,并存储在第三个数组中。
但我没有得到预期的结果。相反,我得到一些随机数字。 你能帮我搞清楚我做错了什么吗?
array11
和array22
是前2个数组array_result
是生成的数组dim1
和dim2
是前2个数组的维度 dim3
是第三个数组的维度,它是在...之外计算的
功能如下:
dim3 = dim1 * dim2;
#include <iostream>
using namespace std;
void remplir(int array[], int dim);
void aficher(int array[], int dim);
void multiplier(int array11[], int array22[], int dim1, int dim2, int dim3);
int main() {
int dim1 = 0, dim2 = 0, dim3;
cout << "La dimension de la 1ere table?" << endl;
cin >> dim1;
while (dim1 > 20) {
cout << "La dimension maximum est 20! Reessayez!" << endl;
cin >> dim1;
}
int array1[dim1];
remplir(array1, dim1);
aficher(array1, dim1);
cout << "La dimension de la 2eme table?" << endl;
cin >> dim2;
while (dim2 > 20) {
cout << "La dimension maximum est 20! Reessayez!" << endl;
cin >> dim2;
}
int array2[dim2];
remplir(array2, dim2);
aficher(array2, dim2);
cout<<"////////////////////////////////////////////////////////"<<endl;
dim3 = dim1 * dim2;
multiplier(array1, array2, dim1, dim2, dim3);
cout << "dim3 = " << dim3 << endl;
return 0;
}
void remplir(int array[], int dim) {
int i = 0;
for (i = 0; i < dim; i = i + 1) {
cout << "Entrez la case numero " << i << endl;
cin >> array[i];
}
}
void aficher(int array[], int dim) {
int i = 0;
for (i = 0; i < dim; i = i + 1) {
cout << "indice " << i << " = " << array[i] << endl;
}
}
void multiplier(int array11[], int array22[], int dim1, int dim2, int dim3) {
int i, j, k = 0;
int resultat[dim3]; //resulting array
for (i = 0; i <= dim1 - 1; i = i + 1) {
for (j = 0; j <= dim2 - 1; j = j + 1) {
resultat[k++] = array11[i] * array22[j];
}
}
aficher(resultat, dim3); //function that prints the resulting array
}
答案 0 :(得分:0)
k
永远不会增加,所以你继续将乘法数组的值存储在array_result
的第一个元素中。你可以尝试:
array_result[k++] = array11[i] * array22[j];
那将使用k
的值,然后再增加它。您还应该考虑默认初始化您的array_result
,如下所示:
int array_result[dim3] = {}; // initialise all values to 0
这意味着你不会得到随机数,你会看到所有数字,但第一个是0。