这是一篇关于数组的文章!希望能够帮助你加深对于数组的理解。
如有错误,请不吝赐教!
数组是一种数据结构,它是一串用于存放数据的连续的内存空间。
数组的定义就像正常的变量一样,区别是在后面要加上[]。
定义以及初始化方式:
1.int a[]={1,2,3,4,5};//这种方式等价于给中括号里加上5
2.int a[5]={1,2};
3.int *a;(int*)malloc(sizeof(int)*a);//这种定义方式是比较推荐的,下面是它的初始化方式。
利用memset函数:memset(a,0,sizeof(int)*n)这种初始化方式也可以应用于上面两种。
使用完毕后要free(a),并且让a=NULL。
4.定义二维数组和以上大致相同。
int a[2][3]={{1,2,3},{3,4,5}};其中2是行数,3是列数。
如果 int a[][],那么不要忘了初始化。
int **a;(int **)malloc(sizeof(int)*m*n)//m行n列
int *a[5]={{1,2,3},{3,4,6}}->int a[5][3]
tip:如果数组初始化时是a[2]={1},那么只有a[0]变成了1,其它仍然是0。
对数组的内容操作
一般情况下,只需要使用a[1]就可以调用a数组中的第二个成员(第一个是0)。
也可以使用*(a+1)来获取其第二个成员的数值。
在二维数组中,使用a[1][1]来获得二行二列的数值,也可以用*((*a+1)+1)来获得2行2列的数值。a在这个情况下是一个行地址,对它进行+1的操作,实际上内存会移动n格(列数)。对它取数值后,这个情况下*(a+1)是一个列地址,再进行+1操作,只会移动1格。然后对列地址取数值,就可以得到2行2列的数值了。
数组作为参数被调用
传入数组名时,参数是一个地址。传入二维数组时,必须要定义列。二维数组名作为光棍变成参数是不可以的。在作为参数的情况下 *a[1]->a[][1]。这样,传入一个二维数组名就可以作为参数提供给函数工作了。
数组的优势
相比于链表而言,可以快速定位,快速对某个数进行操作。
代码量小。