我一直在研究一个涉及两个矩阵相乘的问题,我必须从用户那里获取元素。然而,在我打印它们之后获取元素时,第一个矩阵的最后一个元素等于第二个矩阵的第一个元素。结果我得不到正确的结果。如果有人能提供帮助,我将不得不承担责任。感谢。
#include<stdio.h>
int main(){
int i, j, k, n;
// get the size of the square matrices from user
scanf("%d", &n);
// allogate memory for the matrices
int * mul_1 = calloc(n, sizeof(int));
int * mul_2 = calloc(n, sizeof(int));
int * mul_3 = calloc(n, sizeof(int));
//get data from user
for(i=0; i<n; i++){
for(j=0; j<n; j++){
scanf("%d", mul_1+n*i+j);
}
}
for(i=0; i<n; i++){
for(j=0; j<n; j++){
scanf("%d", mul_2+n*i+j);
}
}
// display matrices
printf("Entered matrices are:\n =First=\n");
for(i=0; i<n; i++){
for(j=0; j<n; j++){
printf("%d\t", *(mul_1+n*i+j));
}
printf("\n");
}
printf("=Second=\n");
for(i=0; i<n; i++){
for(j=0; j<n; j++){
printf("%d\t", *(mul_2+n*i+j));
}
printf("\n");
}
//begin matrix multiplicaition
for(i=0; i<n; i++){
for(j=0; j<n; j++){
int sum = 0;
for(k=0; k<n; k++){
int a = *(mul_1 + n*i + k);
int b = *(mul_2 + n*k + j);
sum += a*b;
}
*(mul_3 + i*n + j) = sum;
}
}
//display results
printf("Result:\n");
for(i=0; i<n; i++){
for(j=0; j<n; j++){
printf("%d\t", *(mul_3+n*i+j));
}
printf("\n");
}
return 0;
}
答案 0 :(得分:1)
您没有为n
,mul_1
和mul_2
分配足够的空间(mul_3
),这似乎是n*n
矩阵。
您可以使用 valgrind 来检测此类错误。