C语言数组的学习

什么是数组?

在程序设计中,为了处理方便,把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称为数组。

在C语言中,数组属于构造数据类型。一个数组可以分解为多个数组元素,这些数组元素可以是基本数据类型或是构造类型。因此按数组元素的类型不同,数组又可分为数值数组、字符数组、指针数组、结构数组等各种类别。

什么是一维数组?

如果一个数组的所有元素都不是数组,那么该数组称为一维数组。

对于数组类型说明应注意以下几点:

  1. 不能在方括号中用变量来表示元素的个数,但是可以是符号常数或常量表达式。
  2. 数组名不能与其它变量名相同。

例如:

1 #define FD 5
2 // ...
3 int a[3+2],b[7+FD];
这是合法的。下面就是不正确的
int n=5;
int a[n];

数组元素通常也称为下标变量。必须先定义数组,才能使用下标变量。在C语言中只能逐个地使用下标变量,而不能一次引用整个数组。

比如:printf("%d",a);

一维数组的初始化

给数组赋值的方法除了用赋值语句对数组元素逐个赋值外, 还可采用初始化赋值和动态赋值的方法。

数组初始化赋值是指在数组定义时给数组元素赋予初值。数组初始化是在编译阶段进行的。这样将减少运行时间,提高效率。初始化赋值的一般形式为:
    类型说明符 数组名[常量表达式] = { 值, 值……值 };

可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只 给前面部分元素赋值。

1 int a[10]={0,1,2,3,4};

只能给元素逐个赋值,不能给数组整体赋值。

可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。

 

二维数组

多维数组元素有多个下标,以标识它在数组中的位置,所以也称为多下标变量。

二维数组在概念上是二维的,即是说其下标在两个方向上变化,下标变量在数组中的位置也处于一个平面之中,而不是象一维数组只是一个向量。但是,实际的硬件 存储器却是连续编址的,也就是说存储器单元是按一维线性排列的。如何在一维存储器中存放二维数组,可有两种方式:一种是按行排列, 即放完一行之后顺次放入第二行。另一种是按列排列, 即放完一列之后再顺次放入第二列。

在C语言中,二维数组是按行排列的。即,先存放a[0]行,再存放a[1]行,最后存放a[2]行。每行中有四个元素也是依次存放。由于数组a说明为int类型,该类型占两个字节的内存空间,所以每个元素均占有4个字节。

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。