1、第6章 利用数组处理批量数据,前几章使用的变量都属于基本类型,例如整型、字符型、浮点型数据,这些都是简单的数据类型。它们之间是独立定义,单独占有自己的内存单元,表现不出它们之间的相关性,并且对它们的访问也是孤立的。 对于有些数据,只用简单的数据类型是不够的,难以反映出数据的特点,也难以有效地进行处理。,如果有1000名学生,每个学生有一个成绩,需要求这1000名学生的平均成绩。一批具有同名的同属性的数据就组成一个数组。 用s1,s2,s3,s1000表示每个学生的成绩,能体现内在联系。 C语言用方括号中的数字表示下标,如用s15表示,数组名,数组是一组有序数据的集合。数组中各数据的排列是有一定
2、规律的,下标代表数据在数组中的序号 用一个数组名和下标惟一确定数组中的元素 数组中的每一个元素都属于同一个数据类型,6.1 怎样定义和引用一维数组 6.2 怎样定义和引用二维数组 6.3 字符数组,6.1怎样定义和引用一维数组,6.1.1 怎样定义一维数组 6.1.2 怎样引用一维数组元素 6.1.3 一维数组的初始化 6.1.4 一维数组程序举例,6.1.1怎样定义一维数组,一维数组是数组中最简单的 它的元素只需要用数组名加一个下标,就能惟一确定。在C语言中,数组的下标是从0开始的,例如有一个数组有N个元素,它的第一个元素的序号就为0,第二个元素的序号就为1,以此类推,第N个元素的序号就为N
3、-1。 要使用数组,必须在程序中先定义数组,一维数组的定义 定义方式: 数据类型 数组名常量表达式;,合法标识符,表示元素个数 下标从0开始, :数组运算符 单目运算符 优先级(1) 左结合 不能用( ),例 int a6;,编译时分配连续内存 内存字节数=数组维数*sizeof(元素数据类型),数组名表示内存首地址, 是地址常量,5.1 一维数组,数组必须先定义,后使用 只能逐个引用数组元素,不能一次引用整个数组 数组元素表示形式: 数组名下标 其中:下标可以是常量或整型表达式,例 int i=15;int datai; (不能用变量定义数组维数),例 int a10;printf(“%d”
4、,a); () 必须 for(j=0;j10;j+)printf(“%dt”,aj); (),例 int data5; data5=10; /C语言对数组不作越界检查,使用时要 注意,一维数组的引用,6.1.1怎样定义一维数组,定义一维数组的一般形式为:类型符 数组名常量表达式; 数组名的命名规则和变量名相同 如 int a10;,数组名,6.1.1怎样定义一维数组,定义一维数组的一般形式为:类型符 数组名常量表达式; 类型标识符是指任意一种基本数据类型或者构造数据类型。 数组名是指用户自定义的标识符,它的命名规则和变量名相同 如 int a10;,数组长度,6.1.1怎样定义一维数组,定义一
5、维数组的一般形式为:类型符 数组名常量表达式; 数组名的命名规则和变量名相同 如 int a10;注意:下标是从0开始的 10个元素:a0,a1,a2,a9,每个元素的数据类型,6.1.1怎样定义一维数组,定义一维数组的一般形式为:类型符 数组名常量表达式; int a4+6; 合法 int n=10; int an;不能包含变量,不合法,6.1.1怎样定义一维数组,数组的类型实际上是指数组元素的取值类型。对于同一个数组,其所有元素的数据类型都是相同的。 数组名表示内存首地址,是地址变量。 说明:如果在被调用的函数中定义数组,其长度可以是变量或非常量表达式。但是在执行函数时,数组长度是固定的,
6、静态数组不可用“可变长”,6.1.2 怎样引用一维数组元素,数组是具有相同类型的数据单元的集合。 在定义数组并对其中各元素赋值后,就可以引用数组中的元素。数组元素也是一种变量,其标识方法为数组名后加一个下标。 注意:只能引用数组元素而不能一次整体调用整个数组全部元素的值 应当特别提醒的是:数组元素的下标从0开始,如果用”int a10;”定义数组,则最大下标值为9,不存在数组元素a10。,6.1.2 怎样引用一维数组元素,引用数组元素的表示形式为:数组名下标“下标”可以是整型常量或整型表达式 如a0=a5+a7-a2*3 合法int n=5,a10; an=20;,合法,6.1.2 怎样引用一
7、维数组元素,在引用数组元素的时候,必须使用“”,称为下标运算符,它是优先级别最高的运算符之一。 对已经定义的数组a,数组名a就是该数组在内存中的首地址,即代表了a0在内存中的地址,它不能进行改变,相当于一个地址常量。 输出a是错误的,要指明a中哪个元素。由于不能引用整个数组,只能对逐个元素进行引用,说明ai才是正确的引用方法。,6.1.2 怎样引用一维数组元素,例6.1 对10个数组元素依次赋值为0,1,2,3,4,5,6,7,8,9,要求按逆序输出。 解题思路: 定义一个长度为10的数组,数组定义为整型 要赋的值是从0到9,可以用循环来赋值 用循环按下标从大到小输出这10个元素,#inclu
8、de int main() int i,a10;for (i=0; i=0; i-)printf(“%d “,ai);printf(“n“);return 0;,使a0a9的值为09,a0a1a2a3a4a5a6a7a8a9,#include int main() int i,a10;for (i=0; i=0; i-)printf(“%d “,ai);printf(“n“);return 0;,先输出a9,最后输出a0,a0a1a2a3a4a5a6a7a8a9,6.1.3一维数组的初始化,在定义数组的同时,给各数组元素赋值 int a10=0,1,2,3,4,5,6,7,8,9; int a
9、10=0,1,2,3,4;相当于int a10=0,1,2,3,4,0,0,0,0,0; int a10=0,0,0,0,0,0,0,0,0,0;相当于int a10=0; int a5=1,2,3,4,5;可写为int a =1,2,3,4,5;,6.1.3一维数组的初始化,数组的初始化是在编译阶段进行的。 如果数组程度与提供初值的个数相同,则方括号中的数组长度可以省略。 如果是字符型数组,则系统自动初始化为0,如果是指针型数组,则初始化为NULL,即空指针。,6.1.4一维数组程序举例,例6.2 用数组处理求Fibonacci数列问题 解题思路: 例5.8中用简单变量处理的,只定义了两个或
10、3个变量,程序可以顺序计算并输出各数,缺点不能在内存中保存这些数。假如想直接输出数列中第25个数,是很困难的。 如果用数组处理,每一个数组元素代表数列中的一个数,依次求出各数并存放在相应的数组元素中,#include int main() int i; int f20=1,1; for(i=2;i20;i+)fi=fi-2+fi-1; for(i=0;i20;i+) if(i%5=0) printf(“n”); printf(“%12d”,fi); printf(“n“);return 0; ,例6.3 有10个地区的面积,要求对它们按由小到大的顺序排列。 解题思路: 排序的规律有两种:一种是
11、“升序”,从小到大;另一种是“降序”,从大到小 把题目抽象为:“对n个数按升序排序” 采用起泡法排序,”起泡法”的基本思路是:每次将相邻两个数比较,将小的调到前头。,9 8 5 4 2 0,8 9 5 4 2 0,8 5 9 4 2 0,8 5 4 9 2 0,8 5 4 2 9 0,8 5 4 2 0 9,大数沉淀,小数起泡,a0 a1 a2 a3 a4 a5,for(i=0;iai+1) t=ai;ai=ai+1;ai+1=t; ,8 5 4 2 0 9,5 8 4 2 0 9,5 4 8 2 0 9,5 4 2 8 0 9,5 4 2 0 8 9,a0 a1 a2 a3 a4 a5,fo
12、r(i=0;iai+1) t=ai;ai=ai+1;ai+1=t; ,5 4 2 0 8 9,4 5 2 0 8 9,4 2 5 0 8 9,4 2 0 5 8 9,a0 a1 a2 a3 a4 a5,for(i=0;iai+1) t=ai;ai=ai+1;ai+1=t; ,4 2 0 5 8 9,2 4 0 5 8 9,2 0 4 5 8 9,a0 a1 a2 a3 a4 a5,for(i=0;iai+1) t=ai;ai=ai+1;ai+1=t; ,2 0 4 5 8 9,0 2 4 5 8 9,a0 a1 a2 a3 a4 a5,for(i=0;iai+1) t=ai;ai=ai+1;a
13、i+1=t; ,for(i=0;iai+1) ,for(i=0;iai+1) ,for(i=0;iai+1) ,for(i=0;iai+1) ,for(j=0;j5;j+),int a10; int i,j,t; printf(“input 10 numbers :n“); for (i=0;iai+1) t=ai;ai=ai+1;ai+1=t; printf(“the sorted numbers :n“); for(i=0;i10;i+) printf(“%d “,ai); printf(“n“);,6.2 怎样定义和引用二维数组,1分队,2分队,3分队,队员1,队员2,队员3,队员4,队
14、员5,队员6,float pay36;,6.2.1怎样定义二维数组 6.2.2怎样引用二维数组的元素 6.2.3二维数组的初始化 6.2.4二维数组程序举例,6.2 怎样定义和引用二维数组,6.2 怎样定义和引用二维数组,在现实生活中有很多量是二维的或多维的,例如二维的表格,数学中的矩阵等等,因此C语言中可以构造多维数组。,每个元素ai由包含4个元素 的一维数组组成,二维数组a是由3个元素组成,二维数组理解,二维数组定义的一般形式为类型符 数组名常量表达式常量表达式;如:float a34,b510; 二维数组可被看作是一种特殊的一维数组:它的元素又是一个一维数组 例如,把a看作是一个一维数组
15、,它有3个元素:a0、a1、a2 每个元素又是一个包含4个元素的一维数组,6.2.1怎样定义二维数组,a0,a1,a2,逻辑存储,内存中的存储顺序,6.2 怎样定义和引用二维数组,说明:(1)与一维数组相同,二维数组定义中两个常量表达式必须是常量,不能是变量。 (2)二维数组在物理上是连续编址的,也就是说存储器单元是按一维线性排列的。,二维数组元素的表示形式为:数组名下标下标二维数组元素有两个下标:一个是行标,一个是列标,都必须是整数 b12=a23/2 合法 for(i=0;im;i+)printf(“%d,%dn”,ai0,a0i);合法,6.2.2怎样引用二维数组的元素,int a34=
16、1,2,3,4,5,6,7,8,9,10,11,12; int a34=1,2,3,4,5,6,7,8,9,10,11,12; int a34=1,5,9;等价于 int a34=1,0,0,0,5,0,0,0,9,0,0,0; int a34=1,5,6;相当于 int a34=1,5,6,0;,6.2.3二维数组的初始化,int a34=1,2,3,4,5,6,7,8,9,10,11,12; 等价于: int a 4=1,2,3,4,5,6,7,8,9,10,11,12;int a4=0,0,3, ,0,10;合法,6.2.3二维数组的初始化,例6.4 将一个二维数组行和列的元素互换,存到
17、另一个二维数组中。,6.2.4二维数组程序举例,解题思路: 可以定义两个数组:数组a为2行3列,存放指定的6个数 数组b为3行2列,开始时未赋值 将a数组中的元素aij存放到b数组中的bji元素中 用嵌套的for循环完成,6.2.4二维数组程序举例,#include int main() int a23=1,2,3,4,5,6;int b32,i,j;printf(“array a:n“);for (i=0;i=1;i+) for (j=0;j=2;j+) printf(“%5d“,aij); bji=aij; printf(“n“);,处理a的一行中各元素,处理a中某一列元素,输出a的各元素
18、,a元素值赋给b相应元素,printf(“array b:n“); for (i=0;i=2;i+) for(j=0;j=1;j+)printf(“%5d“,bij);printf(“n“);return 0; ,输出b的各元素,例6.5 有一个34的矩阵,要求编程序求出其中值最大的那个元素的值,以及其所在的行号和列号。 解题思路:采用“打擂台算法” 先找出任一人站在台上,第2人上去与之比武,胜者留在台上 第3人与台上的人比武,胜者留台上,败者下台 以后每一个人都是与当时留在台上的人比武,直到所有人都上台比为止,最后留在台上的是冠军,例6.5 有一个34的矩阵,要求编程序求出其中值最大的那个元
19、素的值,以及其所在的行号和列号。 解题思路:采用“打擂台算法” 先把a00作“擂主”,把它的值赋给变量max max用来存放当前已知的最大值 a01与max比较,如果a01max,则表示a01是已经比过的数据中值最大的,把它的值赋给max,取代了max的原值 以后依此处理,最后max就是最大的值,记行号, int i,j,row=0,colum=0,max;int a34=1,2,3,4,9,8,7,6,-10,10,-5,2; max=a00; for (i=0;imax) max=aij; row=i; colum=j; printf(“max=%dnrow=%dncolum=%dn“,m
20、ax,row,colum); ,记最大值,记列号,6.3.1怎样定义字符数组 6.3.2字符数组的初始化 6.3.3怎样引用字符数组中的元素 6.3.4字符串和字符串结束标志 6.3.5 字符数组的输入输出 6.3.6善于使用字符串处理函数 6.3.7字符数组应用举例,6.3 字符数组,6.3 字符数组,字符型数据是以字符的ASCII代码存储在存储单元中的,一般占一个字节。 字符数组占用一片连续的空间,它的物理存储方法和数值数组是相同的 C语言中没有字符串类型,字符串是存放在字符型数组中的。,用来存放字符数据的数组是字符数组 字符数组中的一个元素存放一个字符 定义字符数组的方法与定义数值型数组
21、的方法类似,6.3.1怎样定义字符数组,char c10; c0=I; c1= ; c2=a; c3=m; c4= ; c5=h; c6=a; c7=p; c8=p; c9=y;,6.3.1怎样定义字符数组,c0c1c2c3c4c5c6c7c8c9,6.3.2字符数组的初始化,对字符数组初始化,最容易理解的方式是用“初始化列表”,把各个字符依次赋给数组中各元素。 如果在定义字符数组时不进行初始化,则数组中各元素的值是不可预料的。 字符数组的引用和数值数组的引用所不同的是字符数组既可以逐个引用,又可以通过字符串整体引用,char c10=I, ,a,m, ,h,a,p,p,y;char c10=
22、c, ,p,r,o,g,r,a,m;,6.3.2字符数组的初始化,c0c1c2c3c4c5c6c7c8c9,c0c1c2c3c4c5c6c7c8c9,char diamond55= , ,*, ,*, ,*,*, , , ,*, ,*, ,*, , ,* ;,6.3.2字符数组的初始化,例6.6 输出一个已知的字符串。 解题思路: 定义一个字符数组,并用“初始化列表”对其赋以初值 用循环逐个输出此字符数组中的字符,6.3.3怎样引用字符数组中的元素,#include int main() char c15=I, ,a,m, ,a, ,s,t,u,d,e,n,t,.;int i;for(i=0;
23、i15;i+)printf(“%c“,ci);printf(“n“);return 0; ,6.3.3怎样引用字符数组中的元素,例6.7 输出一个菱形图。 解题思路: 定义一个字符型的二维数组,用“初始化列表”进行初始化 用嵌套的for循环输出字符数组中的所有元素。 平面菱形图案,每行包括5个字符,其中有的是空白字符,有的是”*”字符,记下在每行中*字符出现的位置。,6.3.3怎样引用字符数组中的元素,#include int main() char diamond5= , ,*, ,*, ,*,*, , , ,*, ,*, ,*, , ,*;int i,j;for (i=0;i5;i+)fo
24、r (j=0;j5;j+)printf(“%c“,diamondij);printf(“n“);return 0; ,在C语言中,是将字符串作为字符数组来处理的 关心的是字符串的有效长度而不是字符数组的长度 为了测定字符串的实际长度,C语言规定了字符串结束标志0 在程序中往往靠检测0的位置来判定字符串是否结束,而不是根据数组的长度来决定字符串长度,0不计入字符串的长度中。打印输出一个没有以0结尾的字符串,其执行结果是无法预知的 在字符串的初始化完成后,对字符数组的操作也是按单个元素进行的,6.3.4字符串和字符串结束标志,0代表ASCII码为0的字符 从ASCII码表可以查到,ASCII码为0
25、的字符不是一个可以显示的字符,而是一个“空操作符”,即它什么也不做 用它作为字符串结束标志不会产生附加的操作或增加有效字符,只起一个供辨别的标志 在执行printf函数时,每输出一个字符检查一次,看下一个字符是否0,遇0就停止输出。,6.3.4字符串和字符串结束标志,char c=”I am happy”; 可写成 char c=”I am happy”; 相当于 char c11=”I am happy”;,6.3.4字符串和字符串结束标志,char c10=”China”; 可写成 char c10=”China”; 从c5开始,元素值均为0只显示 printf(”%s”,c);,6.3.
26、4字符串和字符串结束标志,字符数组的输入输出可以有两种方法:逐个字符输入输出(%c)整个字符串一次输入输出(%s) 输出的字符中不包括结束符0 用%s输出字符串时,printf函数中的输出项是字符数组名,不是数组元素名,6.3.5 字符数组的输入输出,6.3.5 字符数组的输入输出,如果字符数组中某个元素是0,则认为其中有一个字符串,若没有放置0,则认为是放了若干个字符。,如果一个字符数组中包含多个0,则遇第一个0时输出就结束 可以用scanf函数输入一个字符串 scanf函数中的输入项c是已定义的字符数组名,输入的字符串应短于已定义的字符数组的长度,6.3.5 字符数组的输入输出,char
27、c6; scanf(”%s”,c); China 系统自动在China后面加一个0,6.3.5 字符数组的输入输出,char str15,str25,str35; scanf(”%s%s%s”,str1,str2,str3); How are you? ,6.3.5 字符数组的输入输出,str1,str2,str3,6.3.5 字符数组的输入输出,Scanf函数中的输入项如果是字符数组名,不要再加地址符&,因为在C语言中数组名代表该数组的起始地址。 Printf(“%s”,c)按字符数组名c找到其数组起始地址,然后逐个输出其中的字符,直到遇0为止。,在C函数库中提供了一些用来专门处理字符串的函
28、数,使用方便,6.3.6 善于使用字符串处理函数,1.puts函数-输出字符串的函数 其一般形式为:puts (字符数组) 作用是将一个字符串输出到终端 char str20=”China”; puts(str); 输出China,6.3.6 善于使用字符串处理函数,2. gets函数-输入字符串的函数 其一般形式为:gets(字符数组) 作用是输入一个字符串到字符数组,并且得到一个函数值。 char str20; gets(str); /str是已定义的字符数组Computer/返回的函数值是字符数组str的起始地址,6.3.6 善于使用字符串处理函数,3. strcat函数-字符串连接函数
29、,是STRing CATenate的缩写 其一般形式为:strcat(字符数组1,字符数组2) 其作用是把两个字符串连接起来,把字符串2接到字符串1的后面,结果放在字符数组1中,本函数返回值是字符数组1的首地址,6.3.6 善于使用字符串处理函数,使用字符串函数时,在程序开头用#include ,3. strcat函数-字符串连接函数char str130=”People”;char str2=”China”;printf(”%s”, strcat(str1,str2); 输出:PeopleChina,6.3.6 善于使用字符串处理函数,要足够大,4. strcpy和strncpy函数-字符串
30、复制,是STRingCoPY的简写。 strcpy一般形式为:strcpy(字符数组1,字符串2) 作用是将字符串2复制到字符数组1中去 char str110,str2=”China”; strcpy(str1,str2);,6.3.6 善于使用字符串处理函数,str1,4. strcpy和strncpy函数-字符串复制 strcpy一般形式为:strcpy(字符数组1,字符串2) 作用是将字符串2复制到字符数组1中去 char str110,str2=”China”; strcpy(str1,str2);,6.3.6 善于使用字符串处理函数,str1,要足够大,4. strcpy和strn
31、cpy函数-字符串复制 strcpy一般形式为:strcpy(字符数组1,字符串2) 作用是将字符串2复制到字符数组1中去 char str110,str2=”China”; strcpy(str1,str2);,6.3.6 善于使用字符串处理函数,数组名形式,4. strcpy和strncpy函数-字符串复制 strcpy一般形式为:strcpy(字符数组1,字符串2) 作用是将字符串2复制到字符数组1中去 char str110,str2=”China”; strcpy(str1,str2);,6.3.6 善于使用字符串处理函数,数组名或字符串常量,4. strcpy和strncpy函数-
32、字符串复制 strcpy一般形式为:strcpy(字符数组1,字符串2) 作用是将字符串2复制到字符数组1中去 char str110,str2=”China”; strcpy(str1,str2); 相当于 strcpy(str1,”China”);,6.3.6 善于使用字符串处理函数,6.3.6 善于使用字符串处理函数,如果在复制前未对str1数组初始化或赋值,则str1各字节中的内容是无法预知的,复制时将str2中的字符串和其后的0一起复制到字符数组1中 字符数组2可以是一个字符串常量,4. strcpy和strncpy函数-字符串复制char str110,str2=”China”;s
33、tr1=”China”; 错误str1=str2; 错误,6.3.6 善于使用字符串处理函数,4. strcpy和strncpy函数-字符串复制 可以用strncpy函数将字符串2中前面n个字符复制到字符数组1中去 strncpy(str1,str2,2); 作用是将str2中最前面2个字符复制到str1中,取代str1中原有的最前面2个字符 复制的字符个数n不应多于str1中原有的字符,6.3.6 善于使用字符串处理函数,5. strcmp函数-字符串比较函数,是STRing CoMPare的缩写 其一般形式为strcmp(字符串1,字符串2) 作用是比较字符串1和字符串2 strcmp(s
34、tr1,str2); strcmp(”China”,”Korea”); strcmp(str1,”Beijing”);,6.3.6 善于使用字符串处理函数,5. strcmp函数-字符串比较函数 字符串比较的规则是:将两个字符串自左至右逐个字符相比,直到出现不同的字符或遇到0为止 如全部字符相同,认为两个字符串相等 若出现不相同的字符,则以第一对不相同的字符的比较结果为准,6.3.6 善于使用字符串处理函数,5. strcmp函数-字符串比较函数”A”A”computer”compare”these”that” ”1A”$20”CHINA”CANADA”DOG”TSINGHUA”,6.3.6
35、善于使用字符串处理函数,5. strcmp函数-字符串比较函数 比较的结果由函数值带回 如果字符串1=字符串2,则函数值为0 如果字符串1字符串2,则函数值为一个正整数 如果字符串1字符串2,则函数值为一个负整数,6.3.6 善于使用字符串处理函数,5. strcmp函数-字符串比较函数 if(str1str2) printf(”yes”); 错误 if(strcmp(str1,str2)0)printf(”yes”); 正确,6.3.6 善于使用字符串处理函数,6. strlen函数-测字符串长度的函数,是STRing LENgth的缩写 其一般形式为:strlen (字符数组) 它是测试字
36、符串长度的函数 函数的值为字符串中的实际长度,6.3.6 善于使用字符串处理函数,6. strlen函数-测字符串长度的函数char str10=”China”;printf(”%d”,strlen(str); 输出结果是5 也可以直接测试字符串常量的长度strlen(”China”);,6.3.6 善于使用字符串处理函数,7. strlwr函数-转换为小写的函数,是STRing LoWeRcase的缩写 其一般形式为strlwr (字符串) 函数的作用是将字符串中大写字母换成小写字母,6.3.6 善于使用字符串处理函数,8. strupr函数-转换为大写的函数,是STRing UPpeRca
37、se的缩写 其一般形式为strupr (字符串) 函数的作用是将字符串中小写字母换成大写字母,6.3.6 善于使用字符串处理函数,6.3.6 善于使用字符串处理函数,库函数并非C语言本身的组成部分,而是C语言编译系统为方便用户使用而提供的公共函数。 #include ,例6.8 输入一行字符,统计其中有多少个单词,单词之间用空格分隔开。 解题思路:问题的关键是怎样确定“出现一个新单词了” 从第1个字符开始逐个字符进行检查,判断此字符是否是新单词的开头,如果是,就使变量num的值加1,最后得到的num的值就是单词总数,6.3.7字符数组应用举例,判断是否出现新单词,可以由是否有空格出现来决定(连
38、续的若干个空格作为出现一次空格;一行开头的空格不统计在内) 如果测出某一个字符为非空格,而它的前面的字符是空格,则表示“新的单词开始了”,此时使num累加1 如果当前字符为非空格而其前面的字符也是非空格,则num不应再累加1,6.3.7字符数组应用举例,用变量word作为判别当前是否开始了一个新单词的标志,若word=0表示未出现新单词,如出现了新单词,就把word置成1 前面一个字符是否空格可以从word的值看出来,若word等于0,则表示前一个字符是空格;如果word等于1,意味着前一个字符为非空格,6.3.7字符数组应用举例,Y,c=空格,word=0,N,word=0,Y,word=1
39、 num+,N,if(c= )word=0; else if(word=0) word=1; num+; ,char string81,c; int i,num=0,word=0;gets(string); for (i=0;(c=stringi)!=0;i+) if(c= ) word=0; else if(word=0) word=1; num+; printf(“%d wordsn”,num); ,一定要设初始值,char string81,c; int i,num=0,word=0;gets(string); for (i=0;(c=stringi)!=0;i+) if(c= ) wo
40、rd=0; else if(word=0) word=1; num+; printf(“%d wordsn”,num); ,相当于 c=stringi; c!=0,6.3.7字符数组应用举例,for (i=0;(c=stringi)!=0;i+)/只要字符不是0就继续执行循环 if(c= ) word=0;/如果是空格字符,使word置0 else if(word=0)/如果不是空格字符且word原值为0 循环条件“(c=stringi)!=0”是一个表达式,包含了一个赋值操作和一个关系运算,在此表达式中又包括了一个赋值表达式和关系表达式。,例6.9 有3个字符串,要求找出其中最大者。 解题思
41、路:设一个二维的字符数组str,大小为310。每一行存放一个字符串char str310;,for (i=0;i3;i+)gets (stri);,str0,str1,str2,可以把str0,str1,str2看作3个一维字符数组,可以把它们如同一维数组那样进行处理,经过三次两两比较,就可得到值最大者,把它放在一维字符数组string中if (strcmp(str0,str1)0)strcpy(string,str0); elsestrcpy(string,str1); if (strcmp(str2,string)0)strcpy(string,str2);,#include #inclu
42、de int main ( ) char str310; char string10; int i;for (i=0;i0)strcpy(string,str0); else strcpy(string,str1); if (strcmp(str2,string)0)strcpy(string,str2); printf(“nthe largest:n%sn“,string); return 0; ,6.3.7字符数组应用举例,“大于”是指两个字符串的比较中的“大于” Str0,str1,str2和string是一维字符数组,其中可以存放一个字符串。 最后用%s格式输出string时,遇到st
43、ring中第一个0即结束输出,并不是把string中的全部字符输出,综合举例,一个班级有10名学生,共有3门课程,分别是数学、英语、程序设计,要求编写一个成绩的管理系统,可以输入学生的学号,每门课的成绩以及各门课的平均成绩,并且具有浏览所有学生成绩和根据学号查询各门课及平均成绩的功能。 If(numidij9) /*判断学号是否为数字*/,小结,数组是程序设计中最常用的数据结构 数组是存储同种类型的诸多元素的最佳选择,数组是建立在其他数据类型之上的一种数据类型 传统的C语言要求在定义数组时,数组的元素个数必须是一个常量表达式 数组名是地址常量,不能对数组名进行赋值 C语言中不检查数组是否越界,所以编程人员在使用时务必注意越界检查 C语言中的字符串都是以空字符结束的,代表空字符的常量为0,在scanf()和printf()中,可以使用%s格式说明符来输入输出字符串 二维数组在物理上是连续编址的,也就是说存储器单元是按一维线性排列的,技术提示,数组在内存中的存放既不是水平的也不是垂直的,它们只是连续存储的 数组能定义的最大维数是由编译器决定的,大多数的编译器只能支持到7维数组 当利用变量或变量表达式作为下标引用数组元素时,最好检查下标值是否合法,这样就可以有效地避免越界问题,