C语言初学者必看--动态定义二维数组的方法

C语言初学者必看--动态定义二维数组的方法

首先要明白,二维数组本质上也是一维的,二维只是人为想象出的空间感。

其实二维数组a[i][j]的不同之处在于,它的数组名a是一个二级指针,它直接指向一个指针数组(元素都是指针的数组),a中储存的就是该指针数组的首地址,该指针数组里存储的指针按顺序指向每一行元素的首地址。因此,该指针数组的长度,即为二维数组的行数i。

a[i](即*(a+i))访问的是指向第i行的指针,a[i][j](即*(*(a+i)+j))访问的是第i行第j列的元素。

由此我们可以知道,想要动态地初始化一个二维数组的步骤如下:

1.定义一个二级指针a(以整形为例);

2.使这个二级指针指向一个指针数组,即为a分配长为i的指针数组的地址;

3.通过对a[i]的访问,为二维数组的每行元素申请地址,申请的大小由列宽j决定;

#include

#include

void main(){

int **a;

int i=3;

int j=4;

int k;

a = (int **)malloc(i*sizeof(int *));/*为指向每行的指针申请地址*/

for(i=0;i<3;i++){

a[i]=(int *)malloc(j*sizeof(int));/*为每行的元素申请地址*/

for(k=0;k<4;k++)

a[i][k]=1;/*赋值,以验证是否成功申请*/

}

for(i=0;i<3;i++){

for(j=0;j<4;j++)

printf("%d ",a[i][j]);

printf("\n");

}

}

运行结果如下:

可见思路与代码无误,大家可以用它来求三行四列的行列式了。

// 相关文章

手机QQ怎么删除缓存?手机QQ缓存清空方法图解
《红问号》被停播的问号
365bet足彩论坛

《红问号》被停播的问号

⌛ 07-10 ⚠️ 8985
王者荣耀扁鹊打法教学攻略大全
365bet足彩论坛

王者荣耀扁鹊打法教学攻略大全

⌛ 07-17 ⚠️ 9138