矩阵乘法时的分段错误,c

时间:2012-04-20 15:01:44

标签: c matrix segmentation-fault malloc

尝试运行此代码时,我遇到了分段错误问题:

#include<stdio.h>
#include<stdlib.h>


int mallocMatrix (int ***matrix, int A, int B) {
    int i;
    *matrix=(int**)malloc(sizeof(int*)*B);
        for(i=0;i<A;i++)
            (*matrix)[i]=(int*)malloc(sizeof(int)*A);
};

void fillMatrix (int ***matrix, int A, int B) {
    int i, j;
    for(i=0;i<B;i++)
    {
        for(j=0;j<A;j++)
            {
                 printf("Matrix[%d][%d]: ",i+1,j+1);
                 scanf("%d", &(*matrix)[i][j]);
            }
        }
};

void displayMatrix (int ***matrix, int A, int B) {
    int i, j;
    printf ("\n");
    for(i=0;i<B;i++)
    {
        for(j=0;j<A;j++)
        {
            printf ("%d ", (*matrix)[i][j]);
        }
    printf ("\n");
    }
};

int main(){
    int **matrix;
    int **matrix_two;
    int **matrix_three;
    int a, b, c, d;

    printf ("[1st matrix] number of columns:");
    scanf ("%d", &a);
    printf ("[1st matrix] number of rows:");
    scanf ("%d", &b);

        mallocMatrix (&matrix, a, b);
        fillMatrix (&matrix, a, b);

    printf ("[2nd matrix] number of columns:");
    scanf ("%d", &c);
    printf ("[2nd matrix] number of rows:");
    scanf ("%d", &d);

        if (a==d)
        {
            mallocMatrix (&matrix_two, c, d);
            fillMatrix (&matrix_two, c, d);
        }
        else
        {
            printf ("The number of columns of the 1st. matrix must be equal to the number of rows of the 2nd. matrix");
            return -1;
        }

    displayMatrix (&matrix, a, b);
    displayMatrix (&matrix_two, c, d);

    mallocMatrix (&matrix_three, b, c);

    /* multiplication */

    int i, j, k;
    for(i = 0; i < b; i++)
    {
        for(j = 0; j < c; j++)
        {
            for(k = 0; k < b; k++)
            {
                matrix_three[i][j] = matrix_three[i][j] + matrix[i][k] * matrix_two[k][j];
            }
        }
    }

    /* end of multiplication */

    displayMatrix (&matrix_three, b, c);
}

代码签名/ 乘法 /后弹出问题。例如: - 第一个矩阵是2x2, - 第二次3x2。 我期待结果为3x2矩阵,BUT代码在尝试到达第三列时给出了2x2矩阵和分段错误。请指出错误

1 个答案:

答案 0 :(得分:0)

我想我在mallocMatrix中发现了你的错误:

 for(i=0;i<A;i++)
            (*matrix)[i]=(int*)malloc(sizeof(int)*A);

循环条件错误你说B是行数,所以对于每个rouw你必须分配一个A元素数组,所以循环应该是:

for(i=0;i<B;i++)
                (*matrix)[i]=(int*)malloc(sizeof(int)*A);

所以当你尝试3x2时,第三行永远不会被初始化,因为你的循环只迭代了2次,当你尝试填充最后一行时崩溃