C 语言语法之四数组数据结构
大纲
数组的概念
- 在程序设计中,为了处理方便把具有相同类型的若干变量按有序的形式组织起来,这些按序排列的同类数据元素的集合称为数组
- 数组是具有相同类型的数据组成的有序集合,其中的每一个数据称包含数组元素与数组下标,数组元素是由其所在的位置序号(称数组元素的下标)来区分
- 在 C 语言中数组属于构造数据类型,一个数组可以分解为多个数组元素,这些数组元素可以是基本数据类型或是构造类型。因此按数组元素的类型不同,数组又可分为数值数组、字符数组、指针数组、结构数组等各种类别
一维数组的定义
- 一维数组的定义方式为:类型说明符 数组名 [常量表达式];例如:
int a[10];
表示定义了一个整型数组,数组名为 a,此数组有 10 个元素,10 个元素都是整型变量 - 数组元素的一般引用形式为:数组名 [下标],例如:
int x = a[0]
- 一维数组在内存中的存放时,每个数据元素占用的字节数,就是基本数据类型的字节数,具体存放方式如下:
数组使用注意事项
- 方括号中的常量表达式表示数据元素的个数,也称为数组的长度
- 数组名是用户定义的数组标识符,书写规则应符合标识符的书写规定
- 允许在同一个类型说明中,定义多个数组和多个变量,例如:
int a,b,c,d,k1[10],k2[20];
- 类型说明符是任一种基本数据类型或构造数据类型,对于同一个数组,其所有元素的数据类型都是相同的
- 数组
a[10]
,表示 a 数组有 10 个元素,下标是从 0 开始的,这 10 个元素是 a [0],a [1] … a [8],a [9],按上面的定义,不存在数组元素a[10]
- C 语言不允许对数组的大小作动态定义,即数组的大小不依赖于程序运行过程中变量的值,以下代码是错误的:
1 | /********C语言不允许对数组的大小作动态定义,下面的写法是错误的********/ |
- 数组元素通常也称为下标变量,必须先定义数组,才能使用下标变量;在 C 语言中只能逐个地使用下标变量,而不能一次引用整个数组,例如:
1 | /********输出有10个元素的数组时,必须使用循环语句逐个输出各下标变量********/ |
- 定义数组时用到的
数组名 [常量表达式]
和引用数组元素时用到的数组名[下标]
是有区别的,例如:int a[10];
中的 10 是指数组长度,t=a[6];
是指引用 a 数组中序号为 6 的元素,此时 6 不代表数组长度
一维数组的初始化赋值
- 数组初始化赋值是指在数组定义时给数组元素赋予初值,数组初始化的过程是在编译阶段进行的,这样可以减少运行间,提高运行效率
- 数组赋值的方法除了用赋值语句对数组元素逐个赋值外,还可采用初始化赋值和动态赋值的方法
- 数组初始化赋值的一般形式为:
类型说明符 数组名[常量表达式]={值, 值, ……值};
,例如:int a[10]= {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
- 可以只给一部分数组元素赋值,例如:
int a[10]= {0, 1, 2, 3, 4};
,表示定义 a 数组有 10 个元素,但花括弧内只提供 5 个初值,这代表只给前面 5 个元素赋初值,后 5 个元素值默认缺省为 0 - 在对全部数组元素赋初值时,由于数据的个数已经确定,因此可以不指定数组长度,例如:
int a[5]= {1, 2, 3, 4, 5};
可以写成:int a[ ]= {1, 2, 3, 4, 5};
- 数组动态赋值的代码示例如下:
1 | /********输入五个数,求出最大的数********/ |