C语言程序设计教程第7章课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《C语言程序设计教程第7章课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 教程 课件
- 资源描述:
-
1、11/14/20221语言程序设计教程第7章 数组1.1.数组的引入数组的引入 在前面的程序设计中,所涉及和处理的数据都非常简单,对这些数据采用C语言的基本类型(整型、实型、字符型)来描述就行,但在实际应用中,需要处理的数据往往是复杂多样的。问题:问题:输入中南大学2003级4500名学生的C语言成绩,按成绩从高分到低分排序,输出平均成绩及高于平均成绩的学生成绩。如何编程呢?如何编程呢?语言提供了用户自定义数据的描述方法,即构造类型:由若干基本类型数据按一定的规则构成复杂数据对象。如数组类型。构造数据类型的引入,使我们能较方便地解决上面的问题。11/14/20222语言程序设计教程第7章 数组
2、2.数组的概念数组:具有相同类型的数据组成的序列,是有序集合。数组中的每一个数据称数组元素数组分量下标变量注意注意:数组元素有序不是指元素大小顺序数组元素有序不是指元素大小顺序 11/14/20223语言程序设计教程第7章 数组7.1 7.1 一维数组一维数组7.1.1 一维数组的定义一维数组一维数组:只有一个下标的数组。定义格式定义格式:存储类别 类型标识符 数组名元素个数;说明:说明:1.存储类别存储类别:说明数组的存储属性,即数组的作用域与生成期,可以是静态型(static),自动型(auto)及外部型(extern)。当使用auto型时可以省略。2.类型标识符类型标识符:数组元素的类型
3、。3.数组名的命名规则数组名的命名规则:与标识符的命名规则相同。4.数组数组“元素个数元素个数”:即数组长度,只能是一个整型常量表达式。可以是符号常量。11/14/20224语言程序设计教程第7章 数组 定义了一个自动型整型数组:数组的元素为整型;数组名为数组的元素为整型;数组名为a a;元素个数为元素个数为5 5;下面是合法的数组定义:char str20;/*定义一个有20个元素的字符型数组str*/float score8;/*定义一个有8个元素的浮点型数组score*/#define N 5long dataN;/*定义一个有5个元素的长整型数组data*/short z4*N;/*定
4、义了一个有20个元素的短整型数组z*/其中的数组长度使用的是符号常量其中的数组长度使用的是符号常量 下面的定义是非法的:int n=10;char cn;/*数组长度不能使用变量*/11/14/20225语言程序设计教程第7章 数组:int student35;char name20;float score35;#define student 35float n_studentstudent;int score_studentstudent*3;int person(10);int n=10,an;11/14/20226语言程序设计教程第7章 数组a5=80;a2.5=60;?定义了数组以后,
5、就可使用它了。但不能利用数组名来整体引用一个数组但不能利用数组名来整体引用一个数组,只能只能单个的使用数组元素。单个的使用数组元素。数组元素的描述:由 数组名加方括号中的下标 组成,即:数组名数组名 下标下标 下下 标:标:数组元素在数组中的顺序号,使用整序型表达式。取值范围取值范围:从0到元素个数。C语言不对下语言不对下标越界作语法检查标越界作语法检查。若有定义:int a5;则数组a的元素分别为:a0、a1、a2、a3、a4;但a5不是。每个元素都可作为一个整型变量来使用。如:a0=5;a3=a1+4;aD-B=3;scanf(“%d”,&a4);11/14/20227语言程序设计教程第7
6、章 数组定义了数组以后,就可使用它了。但不能利用数组名来整体引用一个数组但不能利用数组名来整体引用一个数组,只能单个的使用数组元只能单个的使用数组元素素数组元素的描述数组元素的描述:由 数组名加方括号中的下标 组成,即:数组名数组名 下标下标 下下 标:标:数组元素在数组中的顺序号,使用整序型表达式。取值范围取值范围:从0到元素个数。C语言不对下标越界作语法检查语言不对下标越界作语法检查。若有定义:int a5;则数组a的元素分别为:a0、a1、a2、a3、a4;但a5不是。每个元素都可作为一个整型变量来使用。如:a0=5;a3=a1+4;aD-B=3;scanf(“%d”,&a4);a5=8
7、0;a2.5=60;?11/14/20228语言程序设计教程第7章 数组#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问:不用数组能否完成,如何实现?假设是1000个数据呢?:1.循环控制变量的初值、终值及控制条件。2.不能整体输入/出数组 如:printf(“%d”,a);学会如何对数组进行输入输出学会如何对数组进行输入输出11/14/20229语言程序设计教程第7章 数组
8、 数组变量 在内存中分配一片连续的存储单元,数组元素按数组下标从小到大连续存放。a代表首地址(数组起始地址),每个元素字节数相同,因此,根据数组元素序号可以求得数组各元素在内存的地址,并可对数组元素进行随机存取。数组元素地址数组元素地址=数组首地址+元素下标*sizeof(数组类型)例 int a5;设a的首地址为1000,数组a存储示意图如右图所示1006a0a1a2a3a4内存1000 a3的地址=1000+32=100611/14/202210语言程序设计教程第7章 数组:在定义数组的同时,对数组各元素指定初值。初始化是 编译阶段完成。:用赋值语句或输入语句也可给数组素指定初值,是在运行
9、时完成。初始化数组格式:初始化数组格式:static =;或或 =;说明:说明:是用逗号分隔的数组元素的初始值是用逗号分隔的数组元素的初始值(常量)。常量)。中数值的类型必须与中数值的类型必须与一致。一致。11/14/202211语言程序设计教程第7章 数组 若不对auto数组进行初始化,则其初值是不可知的。若一个static或外部数组未进行初始化,则对数值型数组元素,初值为0,而对字符型数组元素,初值为空字符0.对数组初始化的几种方法:在定义数组时,对数组元素赋予初值。例:int a5=0,1,2,3,4;在定义数组时,对部分数组元素赋予初值。例:int a5=1,2;等价 a0=1,a1=
10、2;其它赋0 对全部数组元素赋初值时,可省数组长度,系统自动确定。例:int a=0,1,2,3,4;等价于 int a5=0,1,2,3,4;a0a1a2a3a401234初始化11/14/202212语言程序设计教程第7章 数组例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”,bi);运行结果:array a is:3 4 5 0 0 ar
11、ray b is:-32 1398 40 1170 454考虑:数组b 的值的含义?11/14/202213语言程序设计教程第7章 数组#define N 5#include main()int i,j,k,max,min;static int a5;for(i=0;i5;i+)scanf(%d,&ai);max=min=a0;/*假定第一个元素既是最大的,也是最小的假定第一个元素既是最大的,也是最小的*/j=k=0;/*对分别记录最大,最小元素下标的变量对分别记录最大,最小元素下标的变量j,k初始化初始化*/for(i=0;i5;i+)if(maxai)min=ai;k=i;printf(m
12、ax:a%d=%d,min:a%d=%d,j,max,k,min);若输入若输入:8 2 312 0-10 输出为输出为:max:a2=312,min:a4=-10 11/14/202214语言程序设计教程第7章 数组维数组的定义:存储类别存储类别 类型标识符类型标识符 数组名数组名 行数行数 列数列数;例:float b53;定义了一个53的数组b,即数组为5行3列,可存放15个实型数据。11/14/202215语言程序设计教程第7章 数组例:int a23;定义了一个23的数组a,即数组为2行3列,可存放6个整型数据。2.2.二维数组元素的表示形式:二维数组元素的表示形式:数组名下标下标下
13、标称第一维下标,下标称第二维下标。二维数组类似于数学中的矩阵,由行、列组成。把所有第一维下标相同的元素称为行,所有第二维下标相同的元素称为列。数组a的6个元素如下:a00 a01 a02 a10 a11 a12 11/14/202216语言程序设计教程第7章 数组3.3.多维数组的定义多维数组的定义 根据二维数组的定义,我们可以类推出多维数组的定义。static int b223;/*定义了一个维的静态整型数组*/float c2322;/*定义了一个维浮点型数组*/在数组定义时,多维数组的维从左到右第一个称第一维,第二个称第二维,依此类推。多维数组元素的顺序仍由下标决定。下标的变化是先变最右
14、边的,再依次变化左边的下标。三维数组b的12个元素是:b000 b001 b002 b010 b011 b012b100 b101 b102 b110 b111 b11211/14/202217语言程序设计教程第7章 数组1.1.二维数组元素的引用形式:二维数组元素的引用形式:数组名下标1下标2下标称第一维下标(或称行),下标称第二维下标(或称列)。下标从开始变化,其值分别小于数组定义中的常量表达式与常量表达式。在二维数组中,一个元素的位置由其下标决定。对 float a43;其12个元素是:第()行:a00,a01,a02第()行:a10,a11,a12第()行:a20,a21,a22第()
15、行:a30,a31,a32二维数组的每一个元素都可以作一个变量来使用。如:printf(“%d”,a00);scanf(%d,&a11);a10+=a00+3*a01;11/14/202218语言程序设计教程第7章 数组例例7.4 7.4 二维数组输入输出二维数组输入输出mainint a23;printf(”nInput array a:”);for(j=0;j2;j+)for(k=0;k3;k+)scanf(“%d”,&ajk);/*输入数据到二维数组中输入数据到二维数组中*/printf(”nOutput array a:n”);for(j=0;j2;j+)for(k=0;k3;k+)/
16、*循环三次,输出一行共三个元素循环三次,输出一行共三个元素*/printf(“%4d”,ajk);printf(“n”);/*输出一行后换行,再输出下一行输出一行后换行,再输出下一行*/输入:Input array a:1 2 3 4 5 6输出:Output array a:1 2 3 4 5 6对二维数组的输入输出多使用二层循环结构来实现。外层循环处理各行,对二维数组的输入输出多使用二层循环结构来实现。外层循环处理各行,循环控制变量循环控制变量j作为数组元素的第一维下标;内层循环处理一行的各列元作为数组元素的第一维下标;内层循环处理一行的各列元素,循环控制变量素,循环控制变量k作为元素的第
17、二维下标。作为元素的第二维下标。11/14/202219语言程序设计教程第7章 数组 7.2.3 7.2.3 二维数组的存储结构二维数组的存储结构设有定义设有定义 intint a23;float b32;a23;float b32;a00 a01a02a10a11a12第行第行第行B00b01b10b11b20b21第行第行系统为数组在内存中分配一片连续的内存空间,将二维数组元素按行的顺序存储在所分配的内存区域。数组a与b的各元素的存储顺序如右图所示 11/14/202220语言程序设计教程第7章 数组例7.5 从键盘上输入9个整数,保存在二维数组中,按数组原来位置输出第一行和第一列的所有元
18、素。第0行第1行第2行 0列列列分析:1、输入数组。2、输出数组时要考虑不是所有数据都输出。思考:应该输出的数据在位置关系上有何特点?(关键!)11/14/202221语言程序设计教程第7章 数组#include include.hmain()main()int int i,j,a33;i,j,a33;for(i=for(i=0;i3;i+)/0;i3;i+)/*输入数组输入数组*/for(j=0;j3;j+)for(j=0;j3;j+)printf printf(a(a%d%d%d%d=,i,j);=,i,j);scanf scanf(%d,&aij;(%d,&aij;for(i=0;i3;
19、i+)/for(i=0;i3;i+)/*输出数组输出数组*/for(j=0;j3;j+)for(j=0;j3;j+)if(i=1|j=1)printf(%-6d,aij);else printf(%-6c,);printf(“n”);运行结果11/14/202222语言程序设计教程第7章 数组 分行给二维数组赋初值,每个花括号内的数据对应一行元素。分行给二维数组赋初值,每个花括号内的数据对应一行元素。例:例:int int a23=1,2,3,2,3,4;a23=1,2,3,2,3,4;将所有初值写在一个花括号内,顺序给各元素赋值。将所有初值写在一个花括号内,顺序给各元素赋值。例:例:int
20、int a23=1,2,3,2,3,4;a23=1,2,3,2,3,4;只对部分元素赋值,没有初值对应的元素赋只对部分元素赋值,没有初值对应的元素赋0 0值或空字符(字值或空字符(字符数组)。符数组)。例例:int int a23=1,2,4;a23=1,2,4;给全部元素赋初值或分行初始化时,可不指定第一维大小,给全部元素赋初值或分行初始化时,可不指定第一维大小,其大小系统可根据初值数目与列数(第二维)自动确定;但其大小系统可根据初值数目与列数(第二维)自动确定;但必须指定第二维的大小。必须指定第二维的大小。例:例:int int a3=1,2,3,4,5,6;a3=1,2,3,4,5,6;
21、int int a3=0,0,5;a3=0,0,5;第一维的大小为多少?11/14/202223语言程序设计教程第7章 数组 例7.6 用如下的33矩阵初始化数组a33,求矩阵的转置矩阵。123147456258789369转置矩阵:是将原矩阵元素按行列互换形成的矩阵1:转置矩阵是将原矩阵元素按行列互换形成的。123147456258789369:沿主对角线将对称位置元素互换即可。主对角线11/14/202224语言程序设计教程第7章 数组程序如下:#include include.hmain()main()int int j,k;j,k;intint a33=1,2,3,4,5,6,7,8,
22、9,b33;a33=1,2,3,4,5,6,7,8,9,b33;for(j=0;j3;j+)for(j=0;j3;j+)for(k=0;k3;k+)bfor(k=0;k3;k+)bj jk k=a=ak kj j;for(j=0;j3;j+)for(j=0;j3;j+)for(k=0;k3;k+)for(k=0;k3;k+)printfprintf(“%6d%6d”,bjk);,bjk);printfprintf(“nn”););11/14/202225语言程序设计教程第7章 数组 1.1.利用数组求利用数组求fiboncacifiboncaci数列的前数列的前n n项项例7.7 求求fibo
23、ncaci数列的前数列的前20项项:f0=1 f1=1 fi=fi-1+fi-2 (i=2,3,n)将前将前20项输出到屏幕上,每行五项。项输出到屏幕上,每行五项。分析:分析:根据这个数列的组成规律:从第三项开始,每个数据根据这个数列的组成规律:从第三项开始,每个数据项的值为前两个数据项的和,采用递推方法来实现。可以用项的值为前两个数据项的和,采用递推方法来实现。可以用一个一维整型数组一个一维整型数组fib 20来保存这个数列的前来保存这个数列的前20项。项。11/14/202226语言程序设计教程第7章 数组#include#include main()int i,fib20;fib0=1;
24、fib1=1;for(i=2;i=19;i+)fibi=fibi-1+fibi-2;printf(Fibonaci Numbers are:n);for(i=0;i20;i+)if(i%5=0)printf(n);printf(%7d,fibi);getch();Fibonaci Numbers are:1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 676511/14/202227语言程序设计教程第7章 数组2.2.利用数组处理批量数据利用数组处理批量数据例例7.87.8 从键盘上输入若干学生(不超过100人)的成绩
25、,计算平均成绩,并输出高于平均分的人数及成绩。输入成绩为负时结束。分析:根据题意,可以定义一个有100个元素的一维数组score,先将成绩输入到数组中,并计算平均成绩。然后,将数组中的成绩值一个个与平均值比较,输出高于平均分的成绩。11/14/202228语言程序设计教程第7章 数组程序如下:#include main()float score100,ave,sum=0,x;int i,n=0,count;printf(Input score:);scanf(%f,&x);while(x=0&n=100)sum+=x;scoren+=x;/*输入的成绩保存在数组score中*/scanf(%f
展开阅读全文