数组定义
<类型>变量名称[元素数量]; 如:int grades[100]; double weight[20];
元素数量必须是整数,并且都是从0开始计数的;例如上面的grades[100]不存在,只有grades[0]到grades[99] (100个)
在C99之后元素数量可以为一个变量
数组是一种容器(放东西的东西),特点是:其中所有的元素具有相同的数据类型;一旦创建,不能改变大小
*(数组中的元素在内存中是连续依次排列的)
数组的集成初始化
int a[] = {2,4,6,7,1}; //表示数组中有5个数,从0开始分别为2,4,6,7,1
int a[5] = {1}; //表示数组有5个数,第一个是1,其余为0
int a[5] = {[0]=2, [2]=1, 5, 6}
//表示数组a中啊a[0]为2,a[2]为1a[3]a[4](跟在最后一个指定位置数后面)为5,6,a[1](未指定)为0
数组的大小
sizeof给出整个数组所占据的内容的大小,单位是字节
sizeof(a)/sizeof(a[0]) // 给出a数组中元素的数量
其中sizeof(a[0])给出数组中单个元素的大小,于是相除就得到了数组的单元个数;这样的代码,一旦修改数组中初始的数据,不需要修改遍历的代码
数组的赋值
数组本身不能被赋值,如int a[]={0} ; int b[] =a; 不可以
要把一个数组中的所有元素交给另一个数组,必须使用遍历(唯一给数组赋值的方法)
遍历数组通常都是使用for循环,让循环变量i从O到<数组的长度,这样循环体内最大的i正好是数组最大的有效下标
数组作为函数的参数时,往往需要另一个参数来传入数组的大小,
因为数组作为函数的参数时:不能在[]中给出数组的大小;不能再利用sizeof来计算数组的元素个数
二维数组
int a [3][5]; 可理解为a是一个3行5列的矩阵
二维数组的遍历要两重遍历
二维数组的初始化
int a[][5] = {
{0,1,2,3,4} ,{2,3,4,5,6,}
};
//可理解为二维数组a中有两个一维数组b[0]={0,1,2,3,4}; b[1]={2,3,4,5,6}
列数是必须给出的,行数可以由编译器来数
每行一个{},逗号分隔
最后的逗号可以存在,有古老的传统
如果省略,表示补零