C语言课程第7章 数组课件

上传人:我*** 文档编号:142089628 上传时间:2020-08-16 格式:PPT 页数:72 大小:705.50KB
返回 下载 相关 举报
C语言课程第7章 数组课件_第1页
第1页 / 共72页
C语言课程第7章 数组课件_第2页
第2页 / 共72页
C语言课程第7章 数组课件_第3页
第3页 / 共72页
C语言课程第7章 数组课件_第4页
第4页 / 共72页
C语言课程第7章 数组课件_第5页
第5页 / 共72页
点击查看更多>>
资源描述

《C语言课程第7章 数组课件》由会员分享,可在线阅读,更多相关《C语言课程第7章 数组课件(72页珍藏版)》请在金锄头文库上搜索。

1、第 七 章 数组,7.1 一维数组 7.2 二维数组 7.3 数组的应用 7.4 字符数组与字符串 7.5 数组作为函数的参数 7.6 程序举例,教学目的和基本要求:,要求学生理解数组下标,掌握初始化数组的方法,学会参数传递数组,并基本掌握二维数组及字符数组的使用。,教学重点:,一维数组使用,参数传递数组。,1. 数组的引入:,回顾第五章时我们所讲过的一个程序: 从键盘输入一百个学生的成绩,求总成绩。 当时我们由此引入了循环结构。如果这个程序不是要求和,而是要把这一百个学生的成绩按从高到低的顺序排列,则必须要把这一百个学生的成绩都同时记录下来,也就是说,必须要设定一百个变量。 在C语言中,提供

2、了一种方便的同时设定多个变量的数据类型,这就是数组!前提是,这多个变量必须具有相同的数据类型,比如同为int、long、float、char等等。 数组有一维数组、二维数组和多维数组。,2.数组的概念 数组:具有相同类型的数据组成的序列,是有序集合。 数组中的每一个数据称,数组元素 由其所在的位置序号(称数组元素的下标) 来区分。一个数组元素就是一个相对独立的变量,注意:数组的有序性,是指数组元素存储的有序性,而不是指数组元素值有序。利用这种有序性,在后面的章节中,我们可以方便的用指针解决一些问题。,7.1 一维数组,7.1.1 一维数组的定义 一维数组:只有一个下标的数组。 定义格式 : 存

3、储类别 类型标识符 数组名元素个数; 说明: 1.存储类别:说明数组的存储属性,即数组的作用域与生成期,可以是静态型(static),自动型(auto)及外部型(extern)。当使用auto型时可以省略。 我们现在所用都是auto型,故省略。 2.类型标识符:数组元素的类型。Int、 long、char、float、double等。 3.数组名的命名规则:与标识符的命名规则相同。 4.数组“元素个数”:即数组长度,只能是一个整型常量表达式。可以是符号常量。,例: int a5; 定义了一个auto型整型数组: 数组的元素为整型;数组名为a;元素个数为5,分别叫做: a0、a1、a2、a3、a

4、4;注意:没有a5这个数组元素。 下面是合法的数组定义: char str20; /* 定义一个有20个元素的字符型数组str */ float score8;/* 定义一个有8个元素的浮点型数组score */ #define N 5 long dataN; /* 定义一个有5个元素的长整型数组data */ short z4*N; /* 定义了一个有20个元素的短整型数组z */ 其中的数组长度使用的是符号常量 下面的定义是非法的: int n=10; char cn; /*数组长度不能使用变量 */,例:试判断下列数组定义是否合法: int student35; char name20;

5、 float score35; #define student 35 float n_studentstudent; int score_studentstudent*3; int person(10); int n=10, an;,a5=80; a2.5=60; ?,定义了数组以后,就可使用它了。 但不能利用数组名来整体引用一个数组,只能单个的使用数组元素。 数组元素的描述 : 由 数组名加方括号中的下标 组成, 即:数组名下标 下 标:数组元素在数组中的顺序号,使用整序型表达式。 取值范围:从0到元素个数-1。 C语言不对下标越界作语法检查。 若有定义: int a5; 则数组a的元素分别

6、为: a0、a1、a2、a3、a4;但a5不是。 每个元素都可作为一个整型变量来使用。 如: a0=5;a3=a1+4;aD-B=3;scanf(“%d”, a2.5=60; ?,#include main() int n,a15; for(n=0;n=0;n-) printf(“%4d”,an); 输入:1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 输出:15 14 13 12 11 10 9 8 7 6 5 4 3 2 1,根据数组的有序性,往往使用循环语句来对数组进行处理,用循环控制变量作为数组下标,从而可以以统一的方式来访问数组元素。 例7.1 从键盘输入15

7、个整数,再反序输出。 问:不用数组能否完成,如何实现?假设是1000个数据呢?,注意: 1. 循环控制变量的初值、终值及控制条件。 2.不能整体输入/出数组 如:printf(“%d”,a); 学会如何对数组进行输入输出,7.1.3 一维数组的存储结构与初始化 1.一维数组的存储结构 数组变量 在内存中分配一片连续的存储单元,数组元素按数组下标从小到大连续存放。a代表首地址(数组起始地址),每个元素字节数相同,因此,根据数组元素序号可以求得数组各元素在内存的地址,并可对数组元素进行随机存取。 数组元素地址=数组首地址+元素下标*sizeof(数组类型),例 int a5; 设a的首地址为100

8、0,数组a存储示意图如右图所示,1006,a3的地址=1000+32=1006,2. 一维数组的初始化 含义:在定义数组的同时,对数组各元素指定初值。 初始化是 编译阶段完成。 注意:用赋值语句或输入语句也可给数组素指定初值,是在运行时完成。 初始化数组格式: static =; 或 = ; 说明: 是用逗号分隔的数组元素的初始值(常量)。 中数值的类型必须与一致。,若不对auto数组进行初始化,则其初值是不可知的。 若一个static或外部数组未进行初始化,则对数值型数组元素,初值为0,而对字符型数组元素,初值为空字符0.,对数组初始化的几种方法: 在定义数组时,对全部数组元素赋予初值。 例

9、:int a5=0,1,2,3,4; 在定义数组时,对部分数组元素赋予初值。 例:int a5=1,2; 等价 a0=1,a1=2; 其它赋0 对全部数组元素赋初值时,可省数组长度,系统自动确定。 例:int a =0,1, 2,3,4 ;等价于 int a5=0,1,2,3,4;,例7.2 数组初始化与未初始化比较 #include main() int i,a5=3,4,5,b5; printf(“narray a is:”) for(i=0;i5;i+) printf(“%6d”,ai); printf(“narray b is:”) for(i=0;i5;i+) printf(“%6d

10、”,bi); ,运行结果: array a is:3 4 5 0 0 array b is:-32 1398 40 1170 454,考虑:数组b 的值的含义?,#define N 5 #include main( ) int i,j,k, max,min; static int a5; for (i=0;iai) min=ai;k=i; printf(max:a%d=%d,min:a%d=%d,j,max,k,min); ,例7.3 从键盘上输入5个数,输出最大、最小的元素以及它们的下标,若输入: 8 2 312 0 -10 输出为: max:a2=312,min:a4=-10,若一个一维数

11、组,它的每一个元素亦是类型相同的一维数组时,便构成二维数组。 数组的类型相同:是指数组大小、元素类型相同。 数组的维数:是指数组的下标个数,一维数组元素只有一个下标,二维数组元素有两个下标。 7.2.1 二维数组的定义 1.定义形式: 存储类别 类型标识符 数组名行数列数; 例:float b53; 定义了一个53的数组b,即数组为5行3列,可存放15个实型数据。,7.2 二维数组,例:int a23; 定义了一个23的数组a,即数组为2行3列,可存放6个整型数据。2.二维数组元素的表示形式: 数组名下标下标下标称第一维下标,下标称第二维下标。 二维数组类似于数学中的矩阵 ,由行、列组成。 把

12、所有第一维下标相同的元素称为行,所有第二维下标相同的元素称为列。 数组a的6个元素如下: a00 a01 a02 a10 a11 a12,3. 多维数组的定义,根据二维数组的定义,我们可以类推出多维数组的定义。 static int b223; /*定义了一个维的静态整型数组*/ float c2322; /*定义了一个维浮点型数组*/ 在数组定义时,多维数组的维从左到右第一个称第一维,第二个称第二维,依此类推。多维数组元素的顺序仍由下标决定。下标的变化是先变最右边的,再依次变化左边的下标。 三维数组b的12个元素是: b000 b001 b002 b010 b011 b012 b100 b1

13、01 b102 b110 b111 b112,1.二维数组元素的引用形式: 数组名下标1下标2 下标称第一维下标(或称行),下标称第二维下标(或称列)。下标从开始变化,其值分别小于数组定义中的常量表达式与常量表达式。,7.2.2 二维数组元素的引用,在二维数组中,一个元素的位置由其下标决定。 对 float a43;其12个元素是: 第 ()行:a00,a01,a02 第 ()行:a10,a11,a12 第 ()行:a20,a21,a22 第 ()行:a30,a31,a32,二维数组的每一个元素都可以作一个变量来使用。 如: printf(“%d”,a00); scanf(%d,例7.4 二维

14、数组输入输出,main int a23; printf(”nInput array a:”); for (j=0;j2;j+) for (k=0;k3;k+) scanf(“%d”, /*输出一行后换行,再输出下一行*/ ,输入:Input array a:1 2 3 4 5 6 输出:Output array a: 1 2 3 4 5 6,对二维数组的输入输出多使用二层循环结构来实现。外层循环处理各行,循环控制变量j作为数组元素的第一维下标;内层循环处理一行的各列元素,循环控制变量k作为元素的第二维下标。,7.2.3 二维数组的存储结构 设有定义 int a23; float b32;,系统

15、为数组在内存中分配一片连续的内存空间,将二维数组元素按行的顺序存储在所分配的内存区域。 数组a与b的各元素的存储顺序如右图所示,元素aij的地址为: a+(inj)元素字节数,例7.5 从键盘上输入9个整数,保存在二维数组中,按数组原来位置输出第一行和第一列的所有元素。 ,分析:1、输入数组。2、输出数组时要考虑不是所有数据都输出。 思考:应该输出的数据在位置关系上有何特点?(关键!),#include main() int i,j,a33; for(i= 0;i3;i+) /*输入数组*/ for(j=0;j3;j+) printf(a%d%d=,i,j); scanf(%d, ,for(i

16、=0;i3;i+) /*输出数组*/ for (j=0;j3;j+) if(i=1|j=1) printf(%-6d,aij); else printf(%-6c, ); printf(“n”); ,7.2.4、二维数组的初始化 分行给二维数组赋初值,每个花括号内的数据对应一行元素。 例:int a23=1,2,3,2,3,4; 将所有初值写在一个花括号内,顺序给各元素赋值。 例:int a23=1,2,3,2,3,4; 只对部分元素赋值,没有初值对应的元素赋0值或空字符(字符数组)。 例:int a23=1,2,4; 给全部元素赋初值或分行初始化时,可不指定第一维大小,其大小系统可根据初值数目与列数(第二维)自动确定;但必须指定第二维的大小。 例:int a3=1,2,3,4,5,6; int a3=0,0,5;,第一维的大小为多少?,例7.6 用如下的33

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > PPT模板库 > PPT素材/模板

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号