C语言中如何定义一个二维数组,数组长度由输入值确定?
推荐于2017-12-16
展开全部
可以通过malloc()函数动态分配,示例:
//---------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
typedef int datatype;
datatype **na(const int m,const int n) /*创建一个m行n列的datatype类型数组,返回首地址,如果创建失败则返回NULL*/
{
int i;
datatype **a=(datatype**)malloc(sizeof(datatype *)*m);
if (!a) {
return NULL;
}
else
for (i = 0; i<m; i++) {
a[i]=(datatype*)malloc(sizeof(datatype)*n);
if (!a[i]) {
return NULL;
}
}
return a;
}
void dela(datatype **a,const int m) /*删除用na()函数创建的并且有m行元素的二维数组a*/
{
int i;
for (i = 0; i<m; i++)
free(a[i]);
free(a);
}
int main(void)
{
datatype **dta=na(3,2); /*创建一个3行2列的datatype数组*/
int i,j;
if (!dta) { /*如果创建失败,则输出错误信息并结束程序*/
fprintf(stderr,"MEMORY ERROR\n");
return -1;
}
else
{
for (i=0; i<3; i++) { /*使用刚才创建的二维数组*/
for (j=0; j<2; j++) {
dta[i][j]=i*j;
printf("%d ",dta[i][j]);
}
putchar('\n');
}
}
dela(dta,3); /*动态创建的数组要手动删除*/
return 0;
}
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
typedef int datatype;
datatype **na(const int m,const int n) /*创建一个m行n列的datatype类型数组,返回首地址,如果创建失败则返回NULL*/
{
int i;
datatype **a=(datatype**)malloc(sizeof(datatype *)*m);
if (!a) {
return NULL;
}
else
for (i = 0; i<m; i++) {
a[i]=(datatype*)malloc(sizeof(datatype)*n);
if (!a[i]) {
return NULL;
}
}
return a;
}
void dela(datatype **a,const int m) /*删除用na()函数创建的并且有m行元素的二维数组a*/
{
int i;
for (i = 0; i<m; i++)
free(a[i]);
free(a);
}
int main(void)
{
datatype **dta=na(3,2); /*创建一个3行2列的datatype数组*/
int i,j;
if (!dta) { /*如果创建失败,则输出错误信息并结束程序*/
fprintf(stderr,"MEMORY ERROR\n");
return -1;
}
else
{
for (i=0; i<3; i++) { /*使用刚才创建的二维数组*/
for (j=0; j<2; j++) {
dta[i][j]=i*j;
printf("%d ",dta[i][j]);
}
putchar('\n');
}
}
dela(dta,3); /*动态创建的数组要手动删除*/
return 0;
}
//---------------------------------------------------------------------------
展开全部
int
main()
{
int
iLen;
int
*p=NULL;
int
i;
scanf("%d",&iLen);
if(iLen
<=
0)
{
printf("数组大小不能小于1!\n");
return
-1;
}
p=
(int
*)
malloc(iLen*sizeof(int));
if(p
==
NULL)
{
printf("内存分配错误!\n");
return
-1;
}
for(i
=
0;i
评论
0
0
0
加载更多
main()
{
int
iLen;
int
*p=NULL;
int
i;
scanf("%d",&iLen);
if(iLen
<=
0)
{
printf("数组大小不能小于1!\n");
return
-1;
}
p=
(int
*)
malloc(iLen*sizeof(int));
if(p
==
NULL)
{
printf("内存分配错误!\n");
return
-1;
}
for(i
=
0;i
评论
0
0
0
加载更多
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int main()
{
int iLen;
int *p=NULL;
int i;
scanf("%d",&iLen);
if(iLen <= 0)
{
printf("数组大小不能小于1!\n");
return -1;
}
p= (int *) malloc(iLen*sizeof(int));
if(p == NULL)
{
printf("内存分配错误!\n");
return -1;
}
for(i = 0;i<iLen;i++)
{
p[i]=i;
}
for(i=0;i<iLen;i++)
{
printf("Array[%d]=[%d]\n",i,p[i]);
}
return 0;
}
{
int iLen;
int *p=NULL;
int i;
scanf("%d",&iLen);
if(iLen <= 0)
{
printf("数组大小不能小于1!\n");
return -1;
}
p= (int *) malloc(iLen*sizeof(int));
if(p == NULL)
{
printf("内存分配错误!\n");
return -1;
}
for(i = 0;i<iLen;i++)
{
p[i]=i;
}
for(i=0;i<iLen;i++)
{
printf("Array[%d]=[%d]\n",i,p[i]);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不可以,数组在定义的时候必须先给定大小。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不可以
用链表完成类似功能
用链表完成类似功能
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询