c语言二维数组的动态内存分配

c语言二维数组的动态内存分配

一、 已知行(第二维),列(第一维)由用户输入:

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

注:
先分配行,再分配列;先释放列,在释放行(否则会造成程序崩溃)

  • 12
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值