c - 动态分配和Matrix.Help me

标签 c pointers matrix malloc

我的这段代码有问题。我必须使用动态分配来计算转置矩阵。该代码适用于 2x2 矩阵,但当我增加矩阵的大小(如 3x3)时,它会失败。有人可以帮助我吗?

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

#define LINE 2
#define COLUMN 2


int** createMat(int line,int colum);
void printMat(int **m, int line,int colum);
void assignMat(int **m, int line, int colum);
int** copyMat(int **m, int line, int colum);
int** traspMat(int **m, int line, int colum);

int main(int argc, char **argv){
    int line = LINE;
    int colum = COLUMN;
    int **matrix;
    int **copy_matrix;
    int **trasp_matrix;
    matrix = createMat(line, colum);
    printf("Pre-Assign\n");
    printMat(matrix, line, colum);
    assignMat(matrix, line, colum);
    printf("After-Assign\n");
    printMat(matrix, line, colum);
    copy_matrix = copyMat(matrix, line, colum);
    printf("Matrix Copied\n");
    printMat(copy_matrix, line, colum);
    trasp_matrix = traspMat(matrix, line, colum);
    printf("Transposed matrix\n");
    printMat(trasp_matrix, line, colum);
    free(matrix);
    free(copy_matrix);
    free(trasp_matrix);
    return 0;
}

int** createMat(int line,int colum){
    int **m = (int**)malloc(line * sizeof(int));
    for(int i = 0; i < line; i++){
        m[i] = (int*)malloc(colum * sizeof(int));
    }
    return m;
 }

 void printMat(int **m, int line,int colum){
    for(int i = 0; i < line; i++){
        for(int j = 0; j < colum; j++){
            printf("%d  ", m[i][j]);
        }
        printf("\n");
    }
}

void assignMat(int **m, int line, int colum){
    printf("Inserisci i valori nella matrice (per riga)\n");
    for (int i = 0; i < line; i++){
        for(int j = 0; j < colum; j++){
            printf("> ");
            scanf(" %d", &m[i][j]);
        }
    }
    printf("\n");
}

int** copyMat(int **m, int line, int colum){
    int **new_mat = createMat(line, colum);
    for(int i = 0; i < line; i++){
        for(int j = 0; j < colum; j++){
            new_mat[i][j] = m[i][j];
        }
    }
    return new_mat;
}

int** traspMat(int **m, int line, int colum){
    int **new_m = createMat(line, colum);
    for(int i = 0; i < line; i++){
        for(int j = 0; j < colum; j++){
            new_m[i][j] = m[j][i];
        }
    }
    return new_m;
}

最佳答案

请注意,malloc(line * sizeof(int))分配line整数,而不是line 指针的数量。如果 sizeof(int) != sizeof(int*) 那么你就有大麻烦了。 – 一些程序员家伙

使用int **m = malloc(line * sizeof(*m));来代替。 – RoadRunner

关于c - 动态分配和Matrix.Help me,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41246442/

相关文章:

c - 为什么这里没有生成 Coredump 文件?

c - 将结构作为指针传递,导致数组损坏?

指向内存块中任意字节的 COpaquePointer

c - 在 C 上动态声明的矩阵的大小

python - Numpy 零二维数组 : substituting elements at specific indices

c - 管道 : Bad file descriptor

c++ - v8 javascript API 文档可在 c 中工作

c - GCC,链接库,找不到?

c - 使用 char* 和 unsigned char* 打印整数的内存表示形式

c++ - 除非旋转为 0 度或 180 度,否则物体不会朝它所面对的方向移动