可以通过malloc()函数动态分配,示例:
//---------------------------------------------------------------------------
#include
#include
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
if (!a[i]) {
return NULL;
}
}
return a;
}
void dela(datatype **a,const int m) /*删除用na()函数创建的并且有m行元素的二维数组a*/
{
int i;
for (i = 0; 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
加载更多
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
p[i]=i;
}
for(i=0;i
printf("Array[%d]=[%d]\n",i,p[i]);
}
return 0;
}
不可以,数组在定义的时候必须先给定大小。
不可以
用链表完成类似功能