#include
#include
void rowKnown()
{
int* a[3];//指针的数组
int column = 0;
printf("已知行数为3,请输入列数:\n");
scanf_s("%d",&column);
for (int i = 0; i < 3; i++)
{
a[i] = (int*)malloc(sizeof(int) * column);
}
//一次性分配所有内存(保证内存的连续性)
//a[o] = (int*)malloc(sizeof(int) * column * 3);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < column; j++)
{
a[i][j] = 1;
}
}
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < column; j++)
{
printf("%d ",a[i][j]);
}
printf("\n");
}
for (int i = 0; i < 3; i++)
{
free(a[i]);
}
}
注:
1.已知行的情况使用指针的数组,每个指针作为其对应的一行
(既然是指针的数组,使用的格式可以参照数组的使用)
2.分开分配内存是不连续的,要求连续分配可以一次性分配所有内存,代码注释中有样例
#include
#include
void columnKnown()
{
int(*a)[3];//指向数组的指针
int row;
printf("已知列数为3,请输入行数:\n");
scanf_s("%d",&row);
a = (int(*) [3])malloc(row * sizeof(int*));
for (int i = 0; i < row; i++)
{
for (int j = 0; j < 3; j++)
{
a[i][j] = 1;
}
}
for (int i = 0; i < row; i++)
{
for (int j = 0; j < 3; j++)
{
printf("%d ",a[i][j]);
}
printf("\n");
}
free(a);
}
注:
1.已知列的情况使用指向数组的指针,指针代表数组的个数
2.既然是单个指针,就不需要借助循环来malloc和free
3.开辟空间时以sizeof(int * )为内存单位
【该段代码在释放内存时异常退出,目前未找到原因,有解决者可以留言告知,感激不尽】
#include
#include
void noneKnown()
{
int** arr;
int row, column;
printf("请依次输入二维数组的行和列:\n");
scanf_s("%d%d",&row,&column);
arr = (int**)malloc(row * sizeof(int*));
for (int i = 0; i < row; i++)
{
arr[i] = (int*)malloc(column * sizeof(int));
}
//一次性分配所有内存空间(保证内存空间的连续)
//arr = (int**)malloc(row * sizeof(int*));
//arr[0] = (int*)malloc(sizeof(int) * column * 3);
for (int i = 0; i < row; i++)
{
for (int j = 0; j < column; j++)
{
arr[i][j] = 1;
}
}
for (int i = 0; i < row; i++)
{
for (int j = 0; j < column; j++)
{
printf("%d ", arr[i][j]);
}
printf("\n");
}
for (int i = 0; i < row; i++)
{
free(arr[i]);
}
free(arr);
}
注:
先分配行,再分配列;先释放列,在释放行(否则会造成程序崩溃)