"],[20,"\n","24:\"jNt4\""],[20,"\n","24:\"Qpdz\""],[20,"该函数的作用是向系统申请空间,且以字节为单位。上述一条代码我们用int作为倍数,int占四个字节,也就是说,我们输入n = 3时,得到了12bit的空间。此时数组a(可以将指针看着数组)中每个元素都是int型的。"],[20,"\n","24:\"OrSf\""],[20,"\n","24:\"bbdE\""],[20,"(int*)是强制转换符,意在把函数malloc的返回值类型转换为int*型,这是因为函数malloc的返回值类型的void*,需要将其转换为自己需要的类型。"],[20,"\n","24:\"BgQf\""],[20,"\n","24:\"EujO\""],[20,"如果我们无限向系统申请空间会得到多少的空间呢?我们试一试:"],[20,{"gallery":"https://uploader.shimo.im/f/wHuUxwpKXyqgjjsw.png!thumbnail"},"29:0|30:0|3:\"424px\"|4:\"243px\"|crop:\"\"|frame:\"none\"|ori-height:\"428\"|ori-width:\"747\""],[20,"\n","24:\"BfvO\""],[20,"1024bit == 1kb,所以100*1024*1024 == 100MB."],[20,"\n","24:\"ufST\""],[20,"运行结果:"],[20,"\n","24:\"En0N\""],[20,{"gallery":"https://uploader.shimo.im/f/iDsGsiJQ6uALYTOP.png!thumbnail"},"29:0|30:0|3:\"229px\"|4:\"auto\"|crop:\"\"|frame:\"none\"|ori-height:\"69\"|ori-width:\"360\""],[20,"\n","24:\"meR3\""],[20,"这个结果在不同的电脑里得到的结果是不同的,这是我运行得到的值,你可以在自己的电脑上试试。"]]">
一个简单的程序,实现数组的逆序输出:
实现了以下操作:
有多组数据。每组数据的第1个数是数组的元素个数,此后数组每个元素的值。
我们可以通过
scanf ("%d",&n);
int a[n];
来实现
但这是c99的标准。
在c99之前呢?
我们使用malloc函数来解决这样的问题,程序:
int *a = (int *) malloc ( n * sizeof(int));
值得注意的是要用函数malloc就需要在头文件里写#include
该函数的作用是向系统申请空间,且以字节为单位。上述一条代码我们用int作为倍数,int占四个字节,也就是说,我们输入n = 3时,得到了12bit的空间。此时数组a(可以将指针看着数组)中每个元素都是int型的。
(int*)是强制转换符,意在把函数malloc的返回值类型转换为int*型,这是因为函数malloc的返回值类型的void*,需要将其转换为自己需要的类型。
如果我们无限向系统申请空间会得到多少的空间呢?我们试一试:
1024bit == 1kb,所以100*1024*1024 == 100MB.
运行结果:
这个结果在不同的电脑里得到的结果是不同的,这是我运行得到的值,你可以在自己的电脑上试试。