由下一个数组

时间:2016-07-13 09:48:56

标签: c arrays

我一直在研究一个涉及两个矩阵相乘的问题,我必须从用户那里获取元素。然而,在我打印它们之后获取元素时,第一个矩阵的最后一个元素等于第二个矩阵的第一个元素。结果我得不到正确的结果。如果有人能提供帮助,我将不得不承担责任。感谢。

#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;
}

1 个答案:

答案 0 :(得分:1)

您没有为nmul_1mul_2分配足够的空间(mul_3),这似乎是n*n矩阵。

您可以使用 valgrind 来检测此类错误。