2012-04-20 119 views
0

我试图运行这段代码时面向分段错误问题:代码符号/ 乘法 /后分段故障而矩阵乘法,C

#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矩阵和分段错误。请点误差

+0

您使用的崩溃B作为列数或行数?,我的意思是在mallocMatrix中,我说,嘿! mallocMatrix(矩阵,3,2)是一个3x2矩阵? – DGomez 2012-04-20 15:05:42

+0

b用作行计数 – user1346765 2012-04-20 15:08:16

+2

按照此顺序,不能乘以尺寸为2X2和3X2的两个矩阵。然而,你可以多用2X2的3X2,得到尺寸为3X2的矩阵。另外,2X2和2X3矩阵可以相乘,这将得到尺寸为2X3的结果矩阵。 – tafa 2012-04-20 15:10:54

回答

0

我想我找到了mallocMatrix你的错误:

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

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

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

所以当你尝试3x2的第三行从未初始化,因为你的循环迭代只是2次,当你试图填补了最后一排