#include<stdio.h>
#include<stdlib.h>
//手动输入x,y,创建一个动态数组,p[x][y]
//从0开始初始化,一直初始化到p[x-1][y-1]这个元素,一直递增
void main1()
{
int x,y;
scanf_s("%d%d", &x, &y); //初始化x 8 * 9的二维数组
void *p = malloc(sizeof(int)*x*y); //分配内存,连续的内存
//y必须是一个已知的常量,才能将这片内存当做一个二维数组的内存使用
int(*px)[9] = p; //二维数组(每个元素为有9个元素的一维数组的一维数组)
int number = 0;
for (int i = 0; i < x; i++)
{
for (int j = 0; j < 9; j++)
{
px[i][j] = ++number;
printf("%3d", px[i][j]);
}
putchar('\n');
}
system("pause");
}
void main()
{
int x, y;
scanf_s("%d%d", &x, &y);
int **pp = (int **)malloc(sizeof(int *)*x);
//二级指针可以存储指针数组的地址
//动态分配一片内存,存放指针数组,每一个元素都是一个地址,
//然后将指针数组的首地址传递给pp保存
for (int i = 0; i < x; i++)
{
pp[i] = malloc(sizeof(int)*y); //分配内存,有多少列,每个指针都存储这样一片内存的地址,这样连续的一片内存就是一个一维数组
}
int num = 0;
for (int i = 0; i < x; i++)
{
for (int j = 0; j < y; j++)
{
//pp[i][j] = num++;
*(*(pp + i) + j) = num++;
printf("%3d", pp[i][j]);
}
putchar('\n');
}
//释放内存
for (int i = 0; i < x; i++)
{
free(pp[i]);
}
free(pp);
system("pause");
}
动态二维数组
最新推荐文章于 2024-07-12 18:43:47 发布