《C语言程序设计谭浩强(第四版)期末复习重点.pdf》由会员分享,可在线阅读,更多相关《C语言程序设计谭浩强(第四版)期末复习重点.pdf(37页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 word 文档 可自由复制编辑 第一章 程序设计和 C 语言 1.1.什么是计算机程序 程序:一组计算机能识别和执行的指令。只要让计算机执行这个程序,计算机就会自动地、有条不紊地进行工作 计算机的一切操作都是由程序控制的,离开程序,计算机将一事无成。1.2什么是计算机语言 计算机语言:人和计算机交流信息的、计算机和人都能识别的语言。计算机语言发展阶段:机器语言(由 0 和 1 组成的指令)符号语言(用英文字母和数字表示指令)高级语言(接近于人的自然语言和数学语言)面向过程的语言(非结构化的语言、结构化语言);面向对象的语言 1.3C语言的发展及其特点 C 语言是一种用途广泛、功能强大、使用灵
2、活的过程性编程语言,既可用于编写应用软件,又能用于编写系统软件。因此 C 语言问世以后得到迅速推广。C 语言主要特点:语言简洁、紧凑,使用方便、灵活。(只有 37 个关键字、9 种控制语句;程序书写形式自由,源程序短)运算符丰富。(34 种运算符;把括号、赋值、强制类型转换等都作为运算符处理;表达式类型多样化)数据类型丰富。(包括:整型、浮点型、字符型、数组类型、指针类型、结构体类型、共用体类型;C99 又扩充了复数浮点类型、超长整型、布尔类型;指针类型数据,能用来实现各种复杂的数据结构的运算。)具有结构化的控制语句。(如 ifelse 语句、while 语句、dowhile 语句、switc
3、h 语句、for 语句用函数作为程序的模块单位,便于实现程序的模块化;C 语言是完全模块化和结构化的语言)语法限制不太严格,程序设计自由度大。(对数组下标越界不做检查;对变量的类型使用比较灵活,例如,整型量与字符型数据可以通用;C 语言允许程序编写者有较大的自由度,因此放宽了语法检查)允许直接访问物理地址,能进行位操作,可以直接对硬件进行操作。(C 语言具有高级语言的功能和低级语言的许多功能,可用来编写系统软件;这种双重性,使它既是成功的系统描述语言,又是通用的程序设计语言)用 C 语言编写的程序可移植性好。(C 的编译系统简洁,很容易移植到新系统;在新系统上运行时,可直接编译“标准链接库”中
4、的大部分功能,不需要修改源代码;几乎所有计算机系统都可以使用 C 语言)生成目标代码质量高,程序执行效率高。1.4.1最简单的C语言程序举例 C 语言允许用两种注释方式:/:单行注释,可单独占一行,可出现在一行中其他内容的右侧。/*/:块式注释,可包含多行。1.4.2 C语言程序的结构 C 语言程序的结构特点:1、一个程序由一个或多个源程序文件组成(小程序往往只包括一个源程序文件,一个源程序文件中可以包括三个部分:预处理指令、全局声明、函数定义。)2、函数是 C 程序的主要组成部分(一个 C 程序是由一个或多个函数组成的;必须包含一个 main 函数(只能有一个);每个函数都用来实现一个或几个
5、特定功能;被调用的函数可以是库函数,也可以是自己编制设计的函数。)3、一个函数包括两个部分(函数首部、函数体(声明部分、执行部分)4、程序总是从 main 函数开始执行 5、C 程序对计算机的操作由 C 语句完成(C 程序书写格式是比较自由的:一行内可以写几个语句;一个语句可以分写在多行上。)6、数据声明和语句最后必须有分号 7、C 语言本身不提供输入输出语句 8、程序应当包含注释,增加可读性 1.6 程序设计的任务 1.问题分析 2.设计算法 3.编写程序 4.对源程序进行编辑、编译和连接 5.运行程序,分析结 6.编写程序文档 word 文档 可自由复制编辑 第二章 算法程序的灵魂 一个程
6、序主要包括以下两方面的信息:(1)对数据的描述。在程序中要指定用到哪些数据以及这些数据的类型和数据的组织形式,这就是数据结构。(2)对操作的描述。即要求计算机进行操作的步骤,也就是算法。数据是操作的对象,操作的目的是对数据进行加工处理,以得到期望的结果。著名计算机科学家沃思(Nikiklaus Wirth)提出一个公式:算法+数据结构=程序 一个程序除了算法和数据结构这主要要素外,还应当采用结构化程序设计方法进行程序设计,并且用某一种计算机语言表示。算法、数据结构、程序设计方法和语言工具是一个程序设计人员应具备的知识。2.1什么是算法 广义地说,为解决一个问题而采取的方法和步骤,就称为“算法”
7、。计算机算法可分为两大类别:数值运算算法(目的是求数值解);非数值运算算法(包括面十分广泛,常见的是用于事务管理领域)2.3 算法的特性 一个有效算法应该具有以下特点:(1)有穷性。一个算法应包含有限的操作步骤,而不能是无限的。(2)确定性。算法中的每一个步骤都应当是确定的,而不应当是含糊的、模棱两可的。(3)有零个或多个输入。所谓输入是指在执行算法时需要从外界取得必要的信息。(4)有一个或多个输出。算法的目的是为了求解,“解”就是输出。没有输出的算法是没有意义的。(5)有效性。算法中的每一个步骤都应当能有效地执行,并得到确定的结果。流程图是表示算法的较好的工具。2.4.3 三种基本结构和改进
8、的流程图 三种基本结构:(1)顺序结构 (2)选择结构 (3)循环结构 当型循环结构 直到型循环结构 2.4.5用伪代码表示算法 伪代码是用介于自然语言和计算机语言之间的文字和符号来描述算法。用伪代码写算法并无固定的、严格的语法规则,可以用英文,也可以中英文混用。2.4.6 用计算机语言表示算法 要完成一项工作,包括设计算法和实现算法两个部分。设计算法的目的是为了实现算法。例 2.19 将例 2.17表示的算法(求多项式 的值)用 C 语言表示。#include int main()int sign=1;double deno=2.0,sum=1.0,term;while(deno=100)s
9、ign=-sign;term=sign/deno;sum=sum+term;deno=deno+1;printf(%fn,sum);return 0;2.5 结构化程序设计方法 采取以下方法保证得到结构化的程序:(1)自顶向下;(2)逐步细化;(3)模块化设计;(4)结构化编码。10019914131211 word 文档 可自由复制编辑 第三章 最简单的 C 程序设计 3.1 顺序程序设计举例 例 3.1 有人用温度计测量出用华氏法表示的温度(如 F,今要求把它转换为以摄氏法表示的温度(如 C)。解题思路:找到二者间的转换公式 f代表华氏温度,c 代表摄氏温度 算法:(N-S 图)#incl
10、ude int main()float f,c;定义 f 和 c 为单精度浮点型变量 f=64.0;指定 f 的值 c=(5.0/9)*(f-32);计算 c 的值 printf(f=%fnc=%fn,f,c);输出 f 和 c 的值 return 0;例 3.2 计算存款利息。有 1000 元,想存一年。有三种方法可选:(1)活期,年利率为 r1 (2)一年期定期,年利率为 r2 (3)存两次半年定期,年利率为 r3,请分别计算出一年后按三种方法所得到的本息和。解题思路:确定计算本息和的公式。从数学知识可知:若存款额为 p0,则:活期存款一年后本息和为:p1=p0(1+r1);一年期定期存款
11、,一年后本息和为:p2=p0(1+r2);两次半年定期存款,一年后本息和为:p3=p0(1+r3/2)(1+r3/2)算法:#include int main()float p0=1000,r1=0.0036,r2=0.0225,r3=0.0198,p1,p2,p3;p1=p0*(1+r1);p2=p0*(1+r2);p3=p0*(1+r3/2)*(1+r3/2);printf(”%fn%fn%fn”,p1,p2,p3);return 0;3.2.1 常量与变量 1.常量:在程序运行过程中,其值不能被改变的量。整型常量:如 1000,12345,0,-345;实型常量:十进制小数形式:如 0.
12、34 -56.79 0.0,指数形式:如 12.34e3(代表 12.34103);字符常量:如?,转义字符:如n;字符串常量:如”boy”;符号常量:#define PI 3.1416 )32(95fc)32(95fc word 文档 可自由复制编辑 2.变量:在程序运行期间,变量的值是可以改变的。变量必须先定义,后使用,定义变量时指定该变量的名字和类型。变量名和变量值是两个不同的概念,变量名实际上是以一个名字代表的一个存储地址。从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据。3.常变量:const int a=3;4.标识符:一个对象的名字。语言规定标识符只能由
13、字母、数字和下划线 3 种字符组成,且第一个字符必须为字母或下划线 合法的标识符:如 sum,average,_total,Class,day,BASIC,li_ling 不合法的标识符:M.D.John,¥123,33,3D64,ab 3.2.2 数据类型 所谓类型,就是对数据分配存储单元的安排,包括存储单元的长度(占多少字节)以及数据的存储形式。不同的类型分配不同的长度和存储形式。C语言允许使用的数据类型:整型类型:基本整型(int 型):占 2 个或 4 个字节 短整型(short int):VC+6.0 中占 2 个字节 长整型(long int):VC+6.0 中占 4 个字节 基本
14、类型 双长整型(long long int):C99 新增的 字符型 布尔型 浮点类型(单精度浮点型、双精度浮点型、复数浮点型)枚举类型 空类型 派生类型(指针类型、数组类型、结构体类型、共用体类型、函数类型)3.2.3 整型数据 整型变量的符号属性:整型变量的值的范围包括负数到正数;可以将变量定义为“无符号”类型;扩充的整形类型:有符号基本整型 signed int;无符号基本整型 unsigned int;有符号短整型 signed short int;无符号短整型 unsigned short int;有符号长整型 signed long int;无符号长整型 unsigned long
15、 int 有符号双长整型 signed long long int;无符号双长整型 unsigned long long int 3.2.3 字符数据类型 字符是按其代码(整数)形式存储的,C99 把字符型数据作为整数类型的一种。1.字符与字符代码:大多数系统采用 ASCII字符集 字母:A Z,a z 数字:0 9 专门符号:29 个:!”#&()*等 空格符:空格、水平制表符、换行等 不能显示的字符:空(null)字符(以0表示)、警告(以a表示)、退格(以b表示)、回车(以r表示)等 字符1 和整数1 是不同的概念:字符1 只是代表一个形状为1 的符号,在需要时按原样输出,在内存中以 A
16、SCII码形式存储,占 1 个 word 文档 可自由复制编辑 字节0 0 1 1 0 0 0 1;整数 1 是以整数存储方式(二进制补码方式)存储的,占 2 个或 4 个字节0 0 0 0 0 0 0 0|0 0 0 0 0 0 0 1 2.字符变量:用类型符 char定义字符变量 3.2.5 浮点型数据 浮点型数据是用来表示具有小数点的实数。float型(单精度浮点型):编译系统为 float型变量分配 4 个字节;数值以规范化的二进制数指数形式存放。double型(双精度浮点型):编译系统为 double型变量分配 8 个字节;15 位有效数字 long double(长双精度)型 3.
17、2.6 怎样确定常量的类型 字符常量:由单撇号括起来的单个字符或转义字符。整型常量:不带小数点的数值。系统根据数值的大小确定 int型还是 long型等。浮点型常量:凡以小数形式或指数形式出现的实数。C 编译系统把浮点型常量都按双精度处理;分配 8 个字节 3.2.7 运算符和表达式 3、算术表达式和运算符的优先级与结合性:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合语法规则的式子,称为算术表达式 运算对象包括常量、变量、函数等 语言规定了运算符的优先级和结合性 4、不同类型数据间的混合运算:(1)+、-、*、/运算的两个数中有一个数为 float或 double型,结果是 do
18、uble型。系统将 float型数据都先转换为 double型,然后进行运算(2)如果 int型与 float或 double型数据进行运算,先把 int型和 float型数据转换为 double型,然后进行运算,结果是 double型(3)字符型数据与整型数据进行运算,就是把字符的 ASCII代码与整型数据进行运算 例 3.3 给定一个大写字母,要求用小写字母输出。#include int main()char c1,c2;c1=A;c2=c1+32;printf(%cn,c2);printf(”%dn”,c2);return 0;5、强制类型转换运算符 强制类型转换运算符的一般形式为:(类
19、型名)(表达式)(double)a (将转换成 double类型)(int)(x+y)(将 x+y的值转换成 int型)(float)(5%3)(将 5%3的值转换成 float型)有两种类型转换:系统自动进行的类型转换;强制类型转换 3.3.1 C语句的作用与分类 语句分为以下 5 类:(1)控制语句:if、switch、for、while、dowhile、continue、break、return、goto等(2)函数调用语句 (3)表达式语句 (4)空语句 (5)复合语句 word 文档 可自由复制编辑 在 C 程序中,最常用的语句是:赋值语句;输入输出语句。其中最基本的是赋值语句。例
20、3.4 给出三角形的三边长,求三角形面积。#include#include int main()double a,b,c,s,area;a=3.67;b=5.43;c=6.21;s=(a+b+c)/2;area=sqrt(s*(s-a)*(s-b)*(s-c);printf(a=%ftb=%ft%fn,a,b,c);printf(area=%fn,area);return 0;3.4.1 数据的输入输出举例 例 3.5 求 ax2+bx+c=0方程的根。a、b、c 由键盘输入,设 b2-4ac#include#include int main()double a,b,c,disc,x1,x2,
21、p,q;scanf(%lf%lf%lf,&a,&b,&c);disc=b*b-4*a*c;p=-b/(2.0*a);q=sqrt(disc)/(2.0*a);x1=p+q;x2=p-q;printf(x1=%7.2fnx2=%7.2fn,x1,x2);return 0;3.4.2 有关数据输入输出的概念 几乎每一个 C 程序都包含输入输出,输入输出是程序中最基本的操作之一。(1)所谓输入输出是以计算机主机为主体而言的:从计算机向输出设备(如显示器、打印机等)输出数据称为输出 从输入设备(如键盘、磁盘、光盘、扫描仪等)向计算机输入数据称为输入(2)语言本身不提供输入输出语句,输入和输出操作是由
22、C 标准函数库中的函数来实现的。printf和 scanf不是语言的关键字,而只是库函数的名字(3)在使用输入输出函数时,要在程序文件的开头用预编译指令#include 或#include stdio.h 3.4.3 用printf函数输出数据 在 C程序中用来实现输出和输入的,主要是 printf函数和 scanf函数。这两个函数是格式输入输出函数,用这两个函数时,必须指定格式。1.printf函数的一般格式,printf(格式控制,输出表列)例如:printf(”i=%d,c=%cn”,i,c);2.常用格式字符:格式符:用来输出一个有符号的十进制整数。可以在格式声明中指定输出数据的域宽p
23、rintf(”%5d%5dn”,12,-345);%d 输出 int型数据;%ld输出 long型数据。格式符。用来输出一个字符,char ch=a ;printf(”%c”,ch);或 printf(”%5c”,ch)word 文档 可自由复制编辑 格式符。用来输出一个字符串,printf(”%s”,”CHINA”);f 格式符。用来输出实数,以小数形式输出。不指定数据宽度和小数位数,用%f;指定数据宽度和小数位数。用%m.nf;输出的数据向左对齐,用%-m.nf e格式符。指定以指数形式输出实数。%e,VC+给出小数位数为位,指数部分占 5列,小数点前必须有而且只有 1位非零数字。prin
24、tf(”%e”,123.456);输出:1.234560 e+002。%m.ne,printf(”%13.2e”,123.456);输出:1.23e+002 (前面有 4个空格)3.4.4 用scanf函数输入数据 1.scanf 函数的一般形式:scanf(格式控制,地址表列)2.scanf函数中的格式声明:与 printf函数中的格式声明相似;以开始,以一个格式字符结束,中间可以插入附加的字符,scanf(a=%f,b=%f,c=%f,&a,&b,&c);3.使用 scanf函数时应注意的问题 3.4.5 字符数据的输入输出 1.用 putchar函数输出一个字符,从计算机向显示器输出一个
25、字符,putchar函数的一般形式为:putchar(c)例 3.8 先后输出 BOY三个字符。#include int main()char a=B,b=O,c=Y;putchar(a);putchar(b);putchar(c);putchar(n);return 0;2.用 getchar函数输入一个字符,向计算机输入一个字符,getchar函数的一般形式为:getchar()例 3.9 从键盘输入 BOY三个字符,然后把它们输出到屏幕。#include int main()char a,b,c;a=getchar();b=getchar();c=getchar();putchar(a)
26、;putchar(b);putchar(c);putchar(n);return 0;word 文档 可自由复制编辑 第四章 选择结构程序设计 4.1 选择结构和条件判断 C 语言有两种选择语句:(1)if语句,实现两个分支的选择结构;(2)switch语句,实现多分支的选择结构 例 4.1 在例 3.5的基础上对程序进行改进。题目要求是求 ax2+bx+c=0方程的根。由键盘输入 a,b,c。假设 a,b,c的值任意,并不保证 b2-4ac 0。需要在程序中进行判别,如果 b2-4ac 0,就计算并输出方程的两个实根,否则就输出“方程无实根”的信息。#include#include int
27、main()double a,b,c,disc,x1,x2,p,q;scanf(%lf%lf%lf,&a,&b,&c);disc=b*b-4*a*c;if(disc0)printf(“has not real rootsn”);else p=-b/(2.0*a);q=sqrt(disc)/(2.0*a);x1=p+q;x2=p-q;printf(“real roots:nx1=%7.2fnx2=%7.2fn”,x1,x2);return 0;4.2.1 用if语句处理选择结构举例 例 4.2 输入两个实数,按代数值由小到大的顺序输出这两个数。#include int main()float a
28、,b,t;scanf(%f,%f,&a,&b);if(ab)t=a;a=b;b=t;printf(%5.2f,%5.2fn,a,b);return 0;word 文档 可自由复制编辑 例 4.3 输入 3 个数 a,b,c,要求按由小到大的顺序输出。#include int main()float a,b,c,t;scanf(%f,%f,%f,&a,&b,&c);if(ab)t=a;a=b;b=t;if(ac)t=a;a=c;c=t;if(bc)t=b;b=c;c=t;printf(%5.2f,%5.2f,%5.2fn,a,b,c);return 0;4.2.2 if语句的一般形式 if(表达
29、式)语句 1 else 语句 2 最常用的 3 种 if 语句形式:1.if(表达式)语句 1 (没有 else子句)2.if(表达式)语句 1 else 语句 2 (有 else子句)3.if(表达式)语句 else if(表达式)语句 else if(表达式)语句 else if(表达式)语句 else 语句 m+1 (在 else部分又嵌套了多层的 if 语句)说明:(1)整个 if 语句可写在多行上,也可写在一行上,但都是一个整体,属于同一个语句;(2)“语句 1”“语句 m”是 if 中的内嵌语句,内嵌语句也可以是一个 if 语句;(3)“语句 1”“语句 m”可以是简单的语句,也可
30、以是复合语句。4.3.1 关系运算符及其优先次序 关系运算符:用来对两个数值进行比较的比较运算符 语言提供种关系运算符:(小于)=(小于或等于)大于)=大于或等于)【优先级相同(高)】=(等于)!=(不等于)【优先级相同(低)】关系、算术、赋值运算符的优先级:算数运算符 关系运算符 赋值运算符 4.3.2 关系表达式 关系表达式:用关系运算符将两个数值或数值表达式连接起来的式子;关系表达式的值是一个逻辑值,即“真”或“假”;在 C 的逻辑运算中,以“”代表“真”,以“”代表“假”4.4.1 逻辑运算符及其优先次序 3 种逻辑运算符:&(逻辑与)|(逻辑或)!(逻辑非)&和|是双目(元)运算符!
31、是一目(元)运算符 逻辑表达式(用逻辑运算符将关系表达式或其他逻辑量连接起来的式子)word 文档 可自由复制编辑 逻辑运算的真值表 逻辑运算符的优先次序:!&|(!为三者中最高)与其他运算符的优先次序:赋值运算符&和|关系运算符 算数运算符 b)max=a;else max=b;条件运算符的执行顺序:求解表达式 1;若为非 0(真)则求解表达式 2,此时表达式 2 的值就作为整个条件表达式的值;若表达式 1 的值为 0(假),则求解表达式 3,表达式 3 的值就是整个条件表达式的值 条件运算符优先于赋值运算符;条件运算符的结合方向为“自右至左”。例 4.4 输入一个字符,判别它是否大写字母,
32、如果是,将它转换成小写字母;如果不是,不转换。然后输出最后得到的字符。#include int main()char ch;scanf(%c,&ch);ch=(ch=A&ch=Z)?(ch+32):ch;printf(%cn,ch);return 0;word 文档 可自由复制编辑 4.6 选择结构的嵌套 在 if 语句中又包含一个或多个 if 语句称为 if 语句的嵌套。一般形式:if()else总是与它上面最 if()if()语句 1 近的未配对的 if 配对 else 语句 2 if()语句 1 内嵌 if else 内嵌 if if()语句 3 else语句 2 限定了内嵌 if 范围
33、 else 语句 4 -1(x 0)解题思路:方法 1(1)先后用 3 个独立的 if 语句处理:输入 x scanf(%d,&x);若 x 0,则 y=-1 if(x 0,则 y=1 if(x0)y=1;输出 x 和 y printf(x=%d,y=%dn,x,y);方法 2(2)用一个嵌套的 if 语句处理:输入 x scanf(%d,&x);若 x 0,则 y=-1 if(x0)y=-1;否则 else 若 x=0,则 y=0 if(x=0)y=0;否则 y=1 else y=1;输出 x 和 y printf(x=%d,y=%dn,x,y);4.7 用switch语句实现多分支选择结构
34、 例 4.6、例 4.7 switch语句的作用是根据表达式的值,使流程跳转到不同的语句.switch语句的一般形式 4.8 选择结构程序综合举例 例 4.8 写一程序,判断某一年是否闰年。#include int main()int year,leap;printf(enter year:);scanf(%d,&year);if(year%4=0)if(year%100=0)if(year%400=0)leap=1;else leap=0;else leap=1;else leap=0;if(leap)printf(%d is,year);else printf(%d is not,year
35、);printf(a leap year.n);return 0;word 文档 可自由复制编辑 例 4.9 求 ax2+bx+c=0方程的解。#include#include int main()double a,b,c,disc,x1,x2,realpart,imagpart;scanf(%lf,%lf,%lf,&a,&b,&c);printf(The equation);if(fabs(a)=1e-6)printf(is not a quadraticn);else disc=b*b-4*a*c;if(fabs(disc)1e-6)x1=(-b+sqrt(disc)/(2*a);x2=(
36、-b-sqrt(disc)/(2*a);printf(has distinct real roots:%8.4fand%8.4fn,x1,x2);else realpart=-b/(2*a);imagpart=sqrt(-disc)/(2*a);printf(has complex roots:n);printf(%8.4f+%8.4fin“,realpart,imagpart);printf(%8.4f-%8.4fin,realpart,imagpart);return 0;例 4.10 运输公司对用户计算运输费用。路程(s km)越远,每吨千米运费越低。标准如下:#include s 25
37、0 没有折扣 int main()250s 500 2折扣 500s 1000 5折扣 int c,s;1000s 2000 8折扣 float p,w,d,f;2000s=3000)c=12;else c=s/250;f=p*w*s*(1-d/100);printf(“freight=%10.2fn”,f);return 0;word 文档 可自由复制编辑 第五章 循环结构程序设计 大多数的应用程序都会包含循环结构。循环结构和顺序结构、选择结构是结构化程序设计的三种基本结构,它们是各种复杂程序的基本构造单元。5.2 用while语句实现循环 while 语句的一般形式如下:while(表达式
38、)语句 循环体 “真”时执行循环体语句 “假”时不执行 while 循环的特点是:先判断条件表达式,后执行循环体语句。例 5.1 求 1+2+3+100,即#include int main()int i=1,sum=0;while(i=100)sum=sum+i;i+;printf(sum=%dn,sum);return 0;5.3用dowhile语句实现循环 do-while 语句的特点:先无条件地执行循环体,然后判断循环条件是否成立。一般形式为:do 语句 while(表达式);例 5.2 用 dowhile 语句求:1+2+3+100#include int main()int i=1
39、,sum=0;do sum=sum+i;i+;while(i=100);printf(sum=%dn,sum);return 0;1001nn word 文档 可自由复制编辑 例 5.3 while 和 do-while 循环的比较。int i,sum=0;当 while 后面 int i,sum=0;printf(“i=?”);的表达式的 printf(“i=?”);scanf(“%d”,&i);第一次的值 scanf(“%d”,&i);while(i=10)为“真”时,do 两种循环得到 sum=sum+i;的结果相同;sum=sum+i;i+;否则不相同。i+;while(i=10);p
40、rintf(“sum=%dn,sum);printf(“sum=%dn,sum);5.4用for语句实现循环 for 语句不仅可以用于循环次数已经确定的情况,还可以用于循环次数不确定而只给出循环结束条件的情况。for 语句完全可以代替 while 语句。for 语句的一般形式为:for(表达式 1;表达式 2;表达式 3)语句 设置初始条件,只执 循环条件表达式,用来判定是否 作为循环的调整器,例如 行一次。可以为零个、继续循环。在每次执行循环体前 使循环变量增值,它是在 一个或多个变量设置 先执行此表达式,决定是否继续 执行完循环体后才进行的。初值执行。执行循环。for 语句的执行过程:(1
41、)先求解表达式 1(2)求解表达式 2,若其值为真,执行循环体,然后执行下面第(3)步。若为假,则结束循环,转到第(5)步(3)求解表达式 3(4)转回上面步骤(2)继续执行(5)循环结束,执行 for 语句下面的一个语句 5.5 循环的嵌套 一个循环体内又包含另一个完整的循环结构,称为循环的嵌套。内嵌的循环中还可以嵌套循环,这就是多层循环。3 种循环(while 循环、dowhile 循环和 for 循环)可以互相嵌套。5.7 用break语句提前终止循环 break 语句可以用来从循环体内跳出循环体,即提前结束循环,接着执行循环下面的语句 例 5.4 在全系 1000 学生中,征集慈善募捐
42、,当总数达到 10 万元时就结束,统计此时捐款的人数,以及平均每人捐款的数目。#include#define SUM 100000 int main()float amount,aver,total;int i;for(i=1,total=0;i=SUM)break;aver=total/i;printf(“num=%dnaver=%10.2fn”,i,aver);return 0;word 文档 可自由复制编辑 5.7.2 用continue语句提前结束本次循环 有时不希望终止整个循环的操作,而只希望提前结束本次循环,而接着执行下次循环。这时可以用 continue 语句。例 5.5 要求输
43、出 100200 之间的不能被 3 整除的数。for(n=100;n=200;n+)if(n%3=0)continue;printf(%d ,n);5.7.3 break语句和continue语句的区别 continue 语句只结束本次循环,而不是终止整个循环的执行 break 语句结束整个循环过程,不再判断执行循环的条件是否成立 例 5.6 输出以下 4*5 的矩阵。1 2 3 4 5 2 4 6 8 10 3 6 9 12 15 4 8 12 16 20#include int main()int i,j,n=0;for(i=1;i=4;i+)控制输出 4 行 for(j=1;j=5;j+
44、,n+)控制每行中输出 5 个数据 if(n%5=0)printf(“n”);printf(%dt,i*j);printf(n);return 0;5.8 循环程序举例 例5.7用 /4 1-1/3+1/5-1/7+公式求 的近似值,直到发现某一项的绝对值小于10-6为止(该项不累计加)。#include#include int main()int sign=1;double pi=0,n=1,term=1;while(fabs(term)=1e-6)pi=pi+term;n=n+2;sign=-sign;term=sign/n;pi=pi*4;printf(pi=%10.8fn,pi);re
45、turn 0;word 文档 可自由复制编辑 例 5.8 求费波那西(Fibonacci)数列的前 40 个数。这个数列有如下特点:第 1、2 两个数为 1、1。从第 3 个数开始,该数是其前面两个数之和。即:F1=1 (n=1)F2=1 (n=2)Fn=Fn-1+Fn-2 (n3)这是一个有趣的古典数学问题:有一对兔子,从出生后第 3 个月起每个月都生一对兔子。小兔子长到第 3 个月后每个月又生一对兔子。假设所有兔子都不死,问每个月的兔子总数为多少?#include#include int main()int main()int f1=1,f2=1,f3;int i;int f1=1,f2=
46、1;int i;printf(%12dn%12dn,f1,f2);for(i=1;i=20;i+)for(i=1;i=38;i+)printf(%12d%12d,f1,f2);f3=f1+f2;if(i%2=0)printf(n);printf(%12dn,f3);f1=f1+f2;f1=f2;f2=f2+f1;f2=f3;return 0;return 0;例 5.9 输入一个大于 3 的整数 n,判定它是否素数(prime,又称质数)。#include int main()int n,i;printf(“n=?);scanf(%d,&n);for(i=2;i=n-1;i+)if(n%i=0
47、)break;if(in)printf(%d is notn,n);else printf(%d isn,n);return 0;例 5.10 求 100200 间的全部素数。for(n=101;n=200;n=n+2)k=sqrt(n);for(i=2;i=k+1)printf(%d,n);m=m+1;if(m%10=0)printf(“n”);word 文档 可自由复制编辑 例 5.11 译密码。为使电文保密,往往按一定规律将其转换成密码,收报人再按约定的规律将其译回原文。解题思路:问题的关键有两个:(1)决定哪些字符不需要改变,哪些字符需要改变,如果需要改变,应改为哪个字符 处理的方法是
48、:输入一个字符给字符变量 c,先判定它是否字母(包括大小写),若不是字母,不改变 c 的值;若是字母,则还要检查它是否W到Z的范围内(包括大小写字母)。如不在此范围内,则使变量 c 的值改变为其后第 4 个字母。如果在W到Z的范围内,则应将它转换为 AD(或 ad)之一的字母。(2)怎样使 c 改变为所指定的字母?办法是改变它的 ASCII 值 例如字符变量 c 的原值是大写字母A,想使 c 的值改变为E,只需执行“c=c+4”即可,因为A的 ASCII值为 65,而E 的 ASCII 值为 69,二者相差 4 char c;c=getchar();while(c!=n)if(c=a&c=A&
49、c=W&c=w&c=A&c=a&c=Z&cz)c=c-26;printf(%c,c);第六章利用数组处理批量数据 数组是一组有序数据的集合。数组中各数据的排列是有一定规律的,下标代表数据在数组中的序号。用一个数组名和下标惟一确定数组中的元素。数组中的每一个元素都属于同一个数据类型 6.1.1怎样定义一维数组 一维数组是数组中最简单的。它的元素只需要用数组名加一个下标,就能惟一确定。要使用数组,必须在程序中先定义数组 定义一维数组的一般形式为:类型符 数组名常量表达式;数组名的命名规则和变量名相同,如 int a10;6.1.2怎样引用一维数组元素 在定义数组并对其中各元素赋值后,就可以引用数组
50、中的元素。注意:只能引用数组元素而不能一次整体调用整个数组全部元素的值。引用数组元素的表示形式为:数组名下标,如 a0=a5+a7-a2*3 合法 例 6.1:对 10 个数组元素依次赋值为 0,1,2,3,4,5,6,7,8,9,要求按逆序输出。解题思路:定义一个长度为 10 的数组,数组定义为整型。要赋的值是从 0 到 9,可 以用循环来赋值。word 文档 可自由复制编辑 用循环按下标从大到小输出这 10 个元素#include int main()int i,a10;for(i=0;i=0;i-)printf(%d,ai);printf(n);return 0;6.1.3一维数组的初始