我们知道,C语言中的数组大小是固定的,定义的时候必须要给一个常量值,不能是变量。
这带来了很大的不便,如果数组过小,不能容下所有数组,如果过大,浪费资源。
请实现一个简单的动态数组,能够随时改变大小,不会溢出,也不会浪费内存空间。
下面的代码实现了简单的动态数组:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#include <stdio.h> #include <stdlib.h> int main() { //从控制台获取初始数组大小 int N; int *a; int i; printf ( "Input array length:" ); scanf ( "%d" ,&N); //分配空间 a=( int *) calloc (N, sizeof ( int )); //填充数据 for (i=0;i<N;i++){ a[i]=i+1; printf ( "%-5d" ,a[i]); if ((i+1)%10==0){ printf ( "\n" ); } } //释放内存 free (a); a=NULL; printf ( "\n" ); return 0; } |
运行结果:
1
2
3
|
Input array length:20 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |