很多数据机构,比如栈,链表等,都可以动态分配存储空间
那么数组呢?一般声明时都要指定数组长度,那么数组可以实现动态分配么?
假设数组存的是int型
那么 你先申请10个元素
int* a = (int*)malloc(sizeof(int)*10);
如果又来了个元素,那么你就可以
a=(int *)realloc(a,11*sizeof(int));
求元素个数int i,n=1;
for(i = 0;(a+i)!=NULL;i++)
{
;
}
n=i+1;//n就是元素个数
代码验证~~
#include "stdafx.h" #include<stdio.h> #include<malloc.h> #define n 6//这个n只是为了模拟变长,n可以是其他函数的返回值或者用户输入的数据 int main(int argc, char* argv[]){ int m; int *a,*b,*a_same,*b_same; //----------初始化------------- printf("输入数组a的个数: "); scanf("%d",&m); a=(int*)malloc(m*sizeof(int));//动态分配数组 printf("输入数组a的值: "); for(int i=0;i<n;i++)//这个n只是为了模拟变长,n可以是其他函数的返回值或者用户输入的数据 { if (i<m) { scanf("%d",a+i); } if (i>=m) { a=(int*)realloc(a,(i+1)*sizeof(int)); scanf("%d",a+i); } } printf("%d",a[5]); return 0; }