Mr.*_*ite 3 c allocation matrix
我创建了一个程序,从外部txt文件打印2维矩阵.如果我定义静态矩阵,例如A [10] [10],我的程序就可以工作.但我想动态分配内存.
当我尝试这段代码时:
int **A = (int **)malloc(N * N * sizeof(int));
Run Code Online (Sandbox Code Playgroud)
有以下错误:
dataStructures4.exe中0x00AC159B处的未处理异常:0xC0000005:访问冲突写入位置0xCDCDCDCD.
在这个循环:
for(i=0; i<N; i++){
for(j=0; j<N; j++){
A[i][j] = -1;
}
}
Run Code Online (Sandbox Code Playgroud)
我想我无法正确生成动态矩阵.我应该如何修改我的代码?
您动态创建2d数组作为指向int*
指向一大块int
s 的指针块的指针.
所以有两个步骤:
1)A
指向第一块int*
int **A = (int **)malloc(N * sizeof(int*));
Run Code Online (Sandbox Code Playgroud)
2)它们中的每一个都指向一大块int
s中的第一个
for(i=0; i<N; i++){
A[i] = (int *)malloc(N * sizeof(int));
}
Run Code Online (Sandbox Code Playgroud)
使用指向特定大小的数组的指针:
您可以使用#define来定义N,或者使用变量:
int n = 10 ;
int (*A)[n] = malloc(n * n * sizeof(int));
Run Code Online (Sandbox Code Playgroud)
这样你就获得了一块连续的内存块。