一、总体思路
我们要用malloc函数开辟二维数组的空间,首先要了解什么是二维数组。
int arr[3][4];
类似这样的数组就是二维数组,第一个[中括号]中是数组的行数,第二个[中括号]中是数组的列数。例如:
arr[1][2];
就是在数组的第二行,第三列的数字。
如这样一个二维数组arr[1][2]中储存的数就是4。
我们若想用malloc函数开辟二维数组,那就要用指针的方式,所以有两种方法一种是指针数组的方式,一种是数组指针的方式。
二、用指针数组的方法
2.1 什么是指针数组
本质是一个指针,每一个指针指向一个数组
形式:
int** a = NULL;
其实就是二级指针,我们知道对于普通数组a[ ],我们可以将它写成指针的形式,就是*(a+x),a是数组名也是首元素地址,+x就是取第x处的地址,“ * ” 就是解引用也就是取出地址处的数。那“ int * ”这个数据类型的数组就是指针数组,也就意味着我们创立了一个数组,数据类型是“ int * ”,那么数组里面存储的是一个个地址。
2.2 解题方式
回到题目,我们要用malloc函数建立一个二维数组,如果用指针数组的方式来解题,我们先开辟几个空间用以存放几个地址,然后再根据地址,再用malloc函数开辟我们想要的大小,这样不就变向的开辟出了我们想要的二维数组了吗?
以下是代码:
//eg1:
#include<stdio.h>
#include<stdlib.h>
int main()
{
//开辟空间
int** num = (int**)malloc(sizeof(int*) * 3);
for (int i = 0; i < 3; i++)
{
*(num+i) = (int*)malloc(sizeof(int) * 4);
//num[i] 是一样的
}
//使用空间
int a = 0;
for (int n = 0; n < 3; n++)
{
for (int m = 0; m < 4; m++)
{
*(*(num + n) + m) = a;
a++;
printf("%d ", *(*(num + n) + m));
}
printf("\n");
}
//关闭空间
for (int i = 0; i < 3; i++)
{
free(*(num + i));
}
free(num);
num = NULL;
return 0;
}
三、用数组指针的方法
3.1 什么是数组指针
本质是一个数组,数组中每一个元素都是一个指针
形式:
int a[3][4];
int(*p)[4]; //p是一个数组指针,指向了一个包含4个int型元素的数组
p = a; //将二维数组的首地址赋给p,即a[0]或a[0][0]
p++; //跨过第一行,p指向了a[1][0]
3.2 解题方式
因为本质是一个数组,我们开辟就可以一次开辟,只不过数组指针的数据类型需要注意
int( * )[ ][4];
以下是代码
//eg2:
#include<stdio.h>
#include<stdlib.h>
int main()
{
//开辟空间
int(*num)[4] = (int(*)[][4])malloc(sizeof(int) * 3 * 4);
//使用空间
int a = 0;
for (int n = 0; n < 3; n++)
{
for (int m = 0; m < 4; m++)
{
*(*(num+n)+m) = a++;
//*(num)[m] 也是一样的
printf("%d ", *(*(num + n) + m));
}
printf("\n");
}
//返回空间
free(num);
return 0;
}
四、总结
我们用malloc函数开辟二维数组,首先要了解二维数组的本质,并学会用二级指针来表达二维数组。
无论是数组指针的方式还是指针数组的方式,都需要了解其本质。
数组指针:本质是一个数组。
指针数组:本质是一个指针。
以此利用malloc函数在我们需要的位置开辟空间。