1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > C语言初学者必看--动态定义二维数组的方法

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

时间:2020-09-04 13:20:19

相关推荐

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<Stdlib.h>#include<stdio.h>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");}}

运行结果如下:

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。