怎么定义一个二维动态数组
1个回答
展开全部
一般来讲两种办法:
第一种:连续内存分配
#include "stdio.h"
#include "stdlib.h"
int main()
{
int x,y;
int *p;
scanf("%d%d",&x,&y);
p=(int *)malloc(x*y*sizeof(int));
.....//这样定义要访问第i行第j列应该用*(p+i*y+j)
free(p);
return 0;
}
第二种:通过指针数组+二级指针
#include "stdio.h"
int main()
{
int x,y;//x行y列
int i,j;
int **p;
scanf("%d%d",&x,&y);
p=(int **)malloc(x*sizeof(int*));
if(p==NULL)//分配失败
{
//printf("内存分配失败!\n");
exit(0);
}
for(i=0;i<x;i++)
{
p[i]=(int *)malloc(y*sizeof(int));
if(p[i]==NULL)//分配失败
{
//printf("内存分配失败!\n");
for(j=0;j<i;j++)
free(p[j]);
free(p);
exit(0);
}
}
........//访问第i行第j列:p[i][j]
for(i=0;i<x;i++)//释放内存
free(p[i]);
free(p);
return 0;
}
第一种:连续内存分配
#include "stdio.h"
#include "stdlib.h"
int main()
{
int x,y;
int *p;
scanf("%d%d",&x,&y);
p=(int *)malloc(x*y*sizeof(int));
.....//这样定义要访问第i行第j列应该用*(p+i*y+j)
free(p);
return 0;
}
第二种:通过指针数组+二级指针
#include "stdio.h"
int main()
{
int x,y;//x行y列
int i,j;
int **p;
scanf("%d%d",&x,&y);
p=(int **)malloc(x*sizeof(int*));
if(p==NULL)//分配失败
{
//printf("内存分配失败!\n");
exit(0);
}
for(i=0;i<x;i++)
{
p[i]=(int *)malloc(y*sizeof(int));
if(p[i]==NULL)//分配失败
{
//printf("内存分配失败!\n");
for(j=0;j<i;j++)
free(p[j]);
free(p);
exit(0);
}
}
........//访问第i行第j列:p[i][j]
for(i=0;i<x;i++)//释放内存
free(p[i]);
free(p);
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询