C语言编程:理解一维数组及其初始化

需积分: 31 12 下载量 155 浏览量 更新于2024-08-19 收藏 180KB PPT 举报
"C语言数组练习,给出程序运行结果,涉及一维数组的定义、初始化和使用" 在C语言中,数组是一种非常重要的数据结构,它允许程序员存储多个相同类型的数据元素。数组可以看作是按顺序排列的同类数据元素的集合。在提供的程序示例中,展示了如何使用一维数组并进行操作。 程序的标题是“练习给出运行结果-C语言数组”,其主要任务是计算数组中所有奇数之和。这个程序首先定义了一个名为`p`的一维整数数组,包含7个元素,分别为5, 6, 7, 8, 16, 17, 18。然后通过一个`while`循环遍历数组,检查每个元素是否为奇数(即除以2的余数为1)。如果元素是奇数,就将其累加到变量`j`中。最后,程序打印出`j`的值,即所有奇数之和。 数组在C语言中分为不同的类型,如`int`(整型)、`char`(字符型)、`float`(浮点型)和`double`(双精度浮点型)。它们可以根据需要存储整数、字符、单精度或双精度浮点数。此外,数组还可以按照维数分类,包括一维、二维和多维数组。 在本例中,数组`p`是一维数组,其定义如下:`int p[7] = {5, 6, 7, 8, 16, 17, 18}`。一维数组的定义通常格式为`类型说明符 数组名[常量表达式]`,这里的常量表达式指定了数组的大小。注意,数组的索引是从0开始的,所以`p[0]`对应于第一个元素,`p[6]`对应于最后一个元素。 数组初始化在声明时可以完成,例如: ```c inta[5] = {1, 2, 3, 4, 5}; // 整型数组初始化 floatb[6] = {4.2, 2.3, 1.0, 6.3, 7.4, 9.1}; // 浮点型数组初始化 charc[3] = {'a', 'b', 'c'}; // 字符型数组初始化 ``` 初始化时,可以提供等号后的值列表,列表的长度可以小于数组的长度,未指定的元素会被自动设置为0(对于数值类型)或空字符(对于字符类型)。 在C语言中,数组的大小必须在编译时已知,这意味着不能使用变量来定义数组的大小,如`int n=5; int a[n];`这样的定义是不合法的。但是,可以使用符号常量或常量表达式,如`#define FD 5`,然后用`b[7+FD]`定义数组。 理解和熟练运用数组是掌握C语言的关键部分,因为它提供了批量处理数据的能力,是编写高效算法的基础。在上述程序中,我们看到了如何定义、初始化数组,并通过循环对数组元素进行操作,这些基本概念和技能是编写任何C语言程序的基础。