数组:
数组:就是只能存放一种数据类型,比如int类型的数组、float类型的数组,里面存放的数据称为“元素”
数组的定义:
首先声明数组的类型,然后声明数组元素的个数(也就是需要多少存储空间)
格式: 元素类型 数组名[元素个数];
比如: int a[3];
数组元素有顺序之分,每个元素都有一个唯一的下标(索引),而且都是从0开始
数组元素的访问: a[i]
数组元素的初始化:
int a[3] = {10, 9, 6};
int a[3] = {10,9};
int a[] = {11, 7, 6};
int a[4] = {[1]=11,[0] = 7};
[ ]里面的个数必须是一个固定值,可以是常量(比如6、8)、常量表达式(比如3+4、5*7)。绝对不能使用变量或者变量表达式来表示元素个数,大多数情况下不要省略元素个数
(当数组作为函数的形参和数组初始化时除外)
C语言中编译器是不会对数组下标越界进行检查的,所以自己访问数组元素时要注意
数组的内存细节分析
#include<stdio.h>
int main()
{
char cs[5] = {'a','A','D','e','f'};
printf("%p\n",cs); // 数组名就代表数组的地址
for (int i = 0; i<5; i++)
{
printf("cs[%d]的地址是:%p\n",i ,&cs[i]);
}
return 0;
}
地址分配分析如下:
二维数组的定义:
一个数组能表示一个班人的年龄,如果想表示很多班呢?
什么是二维数组?int ages[3][10]; 三个班,每个班10个人,相当于3行10列,相当于装着3个一维数组
二维数组是一个特殊的一维数组:它的元素是一维数组。例如int a[2][3]可以看作由一维数组a[0]和一维数组a[1]组成,这两个一维数组都包含了3个int类型的元素
定义形式: 类型 数组名[ 行数] [列数] 如:int a[3][5];
二维数组的存放顺序是按行存放的,先存放第一行的元素,再存放第2行的元素。例如int a[2][3]的存放顺序是:a[0][0] → a[0][1] → a[0][2] → a[1][0] → a[1][1] → a[1][2]
二维数组的内存存储分配:
(注意:a[0]、a[1]也是数组,是一维数组,而且a[0]、a[1]就是数组名,因此a[0]、a[1]就代表着这个一维数组的地址)
1> 数组a的地址是ffc1,数组a[0]的地址也是ffc1,即a = a[0];
2> 元素a[0][0]的地址是ffc1,所以数组a[0]的地址和元素a[0][0]的地址相同,即a[0] = &a[0][0];
3> 最终可以得出结论:a = a[0] = &a[0][0],以此类推,可以得出a[1] = &a[1][0]
二维数组的初始化:
int a[3][4] = {1,2,3,4,5,6};
int a[3][4] = {{},{},{}};
字符串:
字符串可近似看为字符数组处理;
常用函数:gets(s):输入字符串(数组)s;
getchar(c):输入字符c;
puts(s):输出字符串(数组)s;
putchar(c):输出字符c;