1、第3章 程序设计初步 第4章 函数与预处理 第5章 数组 第6章 指针 第7章 自定义数据类型,第2篇 面向过程的程序设计,第3章 程序设计初步,Lily,本章主要内容,3.1 基于过程的程序设计和算法 3.2 C+程序和语句 3.3 赋值语句 3.4 C+的输入与输出 3.5 编写顺序结构的程序 3.6 关系运算和逻辑运算 3.7 选择结构和语句 3.8 条件运算符和条件表达式 3.9 多分支选择结构和switch语句 3.10 编写选择结构的程序 3.11 循环结构和循环语句 3.12 循环的嵌套 3.13 break语句和continue语句 3.14 编写循环结构的程序,在基于过程的程
2、序设计中,程序设计者必须指定计算机执行的具体步骤,程序设计者不仅要考虑程序要“做什么”,还要解决“怎么做”的问题,根据程序要“做什么”的要求,写出一个个语句,安排好它们的执行顺序。怎样设计这些步骤,怎样保证它的正确性和具有较高的效率,这就是算法需要解决的问题。,3.1 基于过程的程序设计和算法,一个基于过程的程序应包括以下两方面内容: (1) 对数据的描述。在程序中要指定数据的类型和数据的组织形式,即数据结构(data structure)。 (2) 对操作的描述。即操作步骤,也就是算法(algorithm)。 对于面向过程的程序,可以用下面的公式表示: 程序=算法+数据结构 作为程序设计人员
3、,必须认真考虑和设计数据结构和操作步骤(即算法)。 算法是处理问题的一系列的步骤。算法必须具体地指出在执行时每一步应当怎样做。,3.1.1 算法的概念,不要认为只有“计算”的问题才有算法。广义地说,为解决一个问题而采取的方法和步骤,就称为“算法”。 计算机算法可分为两大类别:数值算法和非数值算法。数值算法的目的是求数值解。非数值算法包括的面十分广泛,最常见的是用于事务管理领域。目前,计算机在非数值方面的应用远远超过了在数值方面的应用。 C+既支持面向过程的程序设计,又支持面向对象的程序设计。无论面向过程的程序设计还是面向对象的程序设计,都离不开算法设计。,算法的表示: 1、自然语言 2、流程图
4、 3、伪代码,由第1章已知,一个程序包含一个或多个程序单位(每个程序单位构成一个程序文件)。每一个程序单位由以下几个部分组成: (1) 预处理命令。如#include命令和#define命令。 (2) 声明部分。例如对数据类型和函数的声明,以及对变量的定义。 (3) 函数。包括函数首部和函数体,在函数体中可以包含若干声明语句和执行语句。 如下面是一个完整的C+程序:,3.2 C+程序和语句,#include /预处理命令 using namespace std; /在函数之外的声明部分 int a=3; /在函数之外的声明部分 int main( ) /函数首部 float b; /函数内的声
5、明部分b=4.5; /执行语句coutab; /执行语句return 0; /执行语句 如果一个变量在函数之外进行声明,此变量是全局变量,它的有效范围是从该行开始到本程序单位结束。如果一个变量在函数内声明,此变量是局部变量,它的有效范围是从该行开始到本函数结束。C+程序结构可以用图31表示。,图3.1,程序应该包括数据描述(由声明语句来实现)和数据操作(由执行语句来实现)。数据描述主要包括数据类型的声明、函数和变量的定义、变量的初始化等。数据操作的任务是对已提供的数据进行加工。 C+程序中最小的独立单位是语句(statement)。它相当于一篇文章中的一个句子。句子是用句号结束的。语句一般是用
6、分号结束的(复合语句是以右花括号结束的)。,C+语句可以分为以下4种: 1. 声明语句 如int a,b;在C语言中,只有产生实际操作的才称为语句,对变量的定义不作为语句,而且要求对变量的定义必须出现在本块中所有程序语句之前。因此C程序员已经养成了一个习惯: 在函数或块的开头位置定义全部变量。在C+中,对变量(以及其他对象)的定义被认为是一条语句,并且可以出现在函数中的任何行,即可以放在其他程序语句可以出现的地方,也可以放在函数之外。这样更加灵活,可以很方便地实现变量的局部化(变量的作用范围从声明语句开始到本函数或本块结束)。,2. 执行语句 通知计算机完成一定的操作。执行语句包括: (1)
7、控制语句,完成一定的控制功能。C+有9种控制语句,即 if( )else (条件语句) for( ) (循环语句) while( ) (循环语句) dowhile( ) (循环语句) continue (结束本次循环语句) break (中止执行switch或循环语句) switch (多分支选择语句) goto (转向语句) return (从函数返回语句),(2) 函数和流对象调用语句。函数调用语句由一次函数调用加一个分号构成一个语句,例如 sort(x,y,z); /假设已定义了sort函数,它有3个参数 coutxendl; /流对象调用语句 (3) 表达式语句。由一个表达式加一个分号
8、构成一个语句。最典型的是: 由赋值表达式构成一个赋值语句。 i=i+1 /是一个赋值表达式 任何一个表达式的最后加一个分号都可以成为一个语句。一个语句必须在最后出现分号。,3. 空语句 下面是一个空语句: ; 即只有一个分号的语句,它什么也不做。,4. 复合语句 可以用 把一些语句括起来成为复合语句。如下面是一个复合语句。 z=x+y; if(z100) z=z-100; coutz; 注意:复合语句中最后一个语句中最后的分号不能省略。,前面已介绍,赋值语句是由赋值表达式加上一个分号构成。 (1)C+的赋值语句具有其他高级语言的赋值语句的功能。但不同的是: C+中的赋值号“”是一个运算符,可以
9、写成 a=b=c=d; 而在其他大多数语言中赋值号不是运算符,上面的写法是不合法的。,3.3 赋值语句,(2) 关于赋值表达式与赋值语句的概念。 在C+中,赋值表达式可以包括在其他表达式之中,例如 if(a=b)0) cout000) cout0endl; 因为在if的条件中不能包含赋值语句。C+把赋值语句和赋值表达式区别开来,增加了表达式的种类,能实现其他语言中难以实现的功能。,C和C+本身都没有为输入和输出提供专门的语句结构。输入输出不是由C+本身定义的,而是在编译系统提供的I/O库中定义的。 C+的输出和输入是用“流”(stream)的方式实现的。 有关流对象cin、cout和流运算符的
10、定义等信息是存放在C+的输入输出流库中的,因此如果在程序中使用cin、cout和流运算符,就必须使用预处理命令把头文件stream包含到本文件中: #include ,3.4 C+的输入与输出,cout语句的一般格式为cout变量1变量2变量n; 在定义流对象时,系统会在内存中开辟一段缓冲区,用来暂存输入输出流的数据。在执行cout语句时,先把插入的数据顺序存放在输出缓冲区中,直到输出缓冲区满或遇到cout语句中的endl(或n,ends,flush)为止,此时将缓冲区中已有的数据一起输出,并清空缓冲区。输出流中的数据在系统默认的设备(一般为显示器)输出。,*3.4.1 输入流与输出流的基本操
11、作,一个cout语句可以分写成若干行。如 coutThis is a simple C+ program.endl; 可以写成 coutThis is /注意行末尾无分号 a C+ program. endl; /语句最后有分号 也可写成多个cout语句,即 coutThis is ; /语句末尾有分号 cout a C+ ; cout program.; coutendl; 以上3种情况的输出均为,This is a simple C+ program. 注意 不能用一个插入运算符“abcd;,可以写成cina /注意行末尾无分号 b /这样写可能看起来清晰些cd; 也可以写成 cina;
12、cinb; cinc; cind; 以上3种情况均可以从键盘输入: 1 2 3 4 也可以分多行输入数据:,1 2 3 4 在用cin输入时,系统也会根据变量的类型从输入流中提取相应长度的字节。如有 char c1,c2; int a; float b; cinc1c2ab; 如果输入 1234 56.78,注意: 34后面应该有空格以便和56.78分隔开。也可以按下面格式输入: 1 2 34 56.78 (在1和2之间有空格) 不能用cin语句把空格字符和回车换行符作为字符输入给字符变量,它们将被跳过。如果想将空格字符或回车换行符(或任何其他键盘上的字符)输入给字符变量,可以用3.4.3节介
13、绍的getchar函数。 在组织输入流数据时,要仔细分析cin语句中变量的类型,按照相应的格式输入,否则容易出错。,上面介绍的是使用cout和cin时的默认格式。但有时人们在输入输出时有一些特殊的要求,如在输出实数时规定字段宽度,只保留两位小数,数据向左或向右对齐等。C+提供了在输入输出流中使用的控制符(有的书中称为操纵符),见书中表3.1。 需要注意的是: 如果使用了控制符,在程序单位的开头除了要加iostream头文件外,还要加iomanip头文件。,*3.4.2 在输入流与输出流中使用控制符,C+还保留了C语言中用于输入和输出单个字符的函数,使用很方便。其中最常用的有getchar函数和
14、putchar函数。 1. putchar函数(字符输出函数) putchar函数的作用是向终端输出一个字符。例如 putchar(c); 它输出字符变量的值。,3.4.3 用getchar和putchar 函数 进行字符的输入和输出,例3.2 输出单个字符。 #include /或者包含头文件stdio.h: #include using namespace std; int main( ) char a,b,c;a=B;b=O;c=Y;putchar(a);putchar(b);putchar(c);putchar(n);putchar(66);putchar(79);putchar(89
15、);putchar(10);return 0; 运行结果为 BOY BOY,可以看到: 用putchar可以输出转义字符,putchar(n)的作用是输出一个换行符,使输出的当前位置移到下一行的开头。putchar(66)的作用是将66作为ASCII码转换为字符输出,66是字母B的ASCII码,因此putchar(66)输出字母B。其余类似。putchar(10)中的10是换行符的ASCII码,putchar(10)输出一个换行符,作用与putchar(n) 相同。 也可以输出其他转义字符,如putchar(101) (输出字符A,八进制的101是A的ASCII码)putchar() (输出单
16、引号字符)putchar(015) (输出回车,不换行,使输出的当前位置移到本行开头),2. getchar函数(字符输入函数) 此函数的作用是从终端(或系统隐含指定的输入设备)输入一个字符。getchar函数没有参数,其一般形式为getchar( )函数的值就是从输入设备得到的字符。 例3.3 输入单个字符。 #include using namespace std; int main( ) char c;c=getchar( ); putchar(c+32); putchar(n);return 0; 在运行时,如果从键盘输入大写字母A并按回车键,就会在屏幕上输出小写字母a。,请注意,ge
17、tchar( )只能接收一个字符。getchar函数得到的字符可以赋给一个字符变量或整型变量,也可以不赋给任何变量,作为表达式的一部分。,在C语言中是用printf函数进行输出,用scanf函数进行输入的。C+保留了C语言的这一用法。在此只作很简单的介绍。 scanf函数一般格式是 scanf(格式控制,输出表列) printf函数的一般格式是 printf(格式控制,输出表列),3.4.4 用scanf和printf函数 进行输入和输出,例3.4 用scanf和printf函数进行输入和输出。 #include using namespace std; int main( ) int a;
18、float b; char c;scanf(%d %c %f, 运行情况如下: 12 A 67.98(本行为输入,输入的3个数据间以空格相间) a=12,b=67.980003,c=A(本行为输出) 输入的整数12送给整型变量a,字符A送给字符变量c,67.98送给单精度变量b。,例3.5 求一元二次方程式ax2+bx+c=0的根。a,b,c的值在运行时由键盘输入,它们的值满足b2-4ac0。 根据求x1,x2的算法。它可以编写出以下C+程序: #include #include /程序要用到数学函数sqrt,应包含头文件cmath using namespace std; int main(
19、 ) float a,b,c,x1,x2;cinabc;x1=(-b+sqrt(b*b-4*a*c)/(2*a);x2=(-b-sqrt(b*b-4*a*c)/(2*a);coutx1=x1endl;coutx2=x2endl;return 0; ,3.5 编写顺序结构的程序,运行情况如下: 4.5 8.8 2.4 x1=-0.327612 x2=-1.17794 如果程序中要用到数学函数,都要包含头文件cmath(也可以用老形式的头文件math.h,但提倡使用C+新形式的头文件,请参阅第14章14.3节)。在写程序时,一定要注意将数学表达式正确地转换成合法的C+表达式。 可以看到: 顺序结构
20、的程序中的各执行语句是顺序执行的。这种程序最简单,最容易理解。,例如,购物在1000元以下的打九五折,1000元及以上的打九折。 C+提供if语句来实现这种条件选择。如 if amount1000 tax=0.95; /amount代表购物总额,tax代表折扣 else tax=0.9; /若amount1000,条件满足,tax=0.95,否则tax=0.9 pay=amount*tax; /pay为实付款 流程可以用右图表示。,3.6 关系运算和逻辑运算,上面if语句中的“amount”是一个比较符,称为关系运算符。 C+的关系运算符有: (大于) = (大于或等于) = (等于) !=
21、(不等于) 优先级相同 (低),3.6.1 关系运算和关系表达式,关于优先次序: 前4种关系运算符(,)的优先级别相同,后两种也相同。前4种高于后两种。例如,“”优先于“”。而“”与“a+b 等效于 c(a+b)ab=c 等效于(ab)=ca=bc 等效于a=(bc) 用关系运算符将两个表达式连接起来的式子,称为关系表达式。,关系表达式的一般形式可以表示为 表达式 关系运算符 表达式 其中的“表达式”可以是算术表达式或关系表达式、逻辑表达式、赋值表达式、字符表达式。 例如,下面都是合法的关系表达式: ab, a+bb+c,(a=3)(b=5), ab)(b=0”的值为“真”。在C和C+中都用数
22、值1代表“真”,用0代表“假”。,练习:假设,a=3,b=2,c=1 ab的值为 (ab) = = c的值 b+cb 则d得到的值为1 f=abc f得到的值为0,C语言没有提供逻辑型数据,关系表达式的值(真或假)分别用数值1和0代表。C+增加了逻辑型数据。逻辑型常量只有两个,即false(假)和true(真)。 逻辑型变量要用类型标识符bool来定义,它的值只能是true和false之一。如 bool found,flag=false; /定义逻辑变量found和flag,并使flag的初值为false found=true; /将逻辑常量true赋给逻辑变量found 由于逻辑变量是用关键
23、字bool来定义的,因此又称为布尔变量。逻辑型常量又称为布尔常量。所谓逻辑型,就是布尔型。,3.6.2 逻辑常量和逻辑变量,在编译系统处理逻辑型数据时,将false处理为0,将true处理为1。因此,逻辑型数据可以与数值型数据进行算术运算。 如果将一个非零的整数赋给逻辑型变量,则按“真”处理,如 flag=123; /赋值后flag的值为true coutflag; 输出为数值1。,有时只用一个关系表达式还不能正确表示所指定的条件。 C+提供3种逻辑运算符: (1) & 逻辑与 (相当于其他语言中的AND) (2) | 逻辑或 (相当于其他语言中的OR) (3) ! 逻辑非 (相当于其他语言中
24、的NOT) 逻辑运算举例如下: a & b 若a,b为真,则a & b为真。 a|b 若a,b之一为真,则a|b为真。 !a 若a为真,则!a为假。 书中表32为逻辑运算的“真值表”。,3.6.3 逻辑运算和逻辑表达式,在一个逻辑表达式中如果包含多个逻辑 运算符,按以下的优先次序: (1) !(非) &(与) (或),即“!”为三者中最高的。 (2) 逻辑运算符中的“&”和“|”低于关系运算符,“!”高于算术运算符。 例如:(ab) & (xy) 可写成 ab & xy(a=b) | (x=y) 可写成 a=b | x=y(!a) | (ab) 可写成 !a | ab 将两个关系表达式用逻辑运
25、算符连接起来就成为一个逻辑表达式,上面几个式子就是逻辑表达式。逻辑表达式的一般形式可以表示为,表达式 逻辑运算符 表达式 逻辑表达式的值是一个逻辑量“真”或“假”。前面已说明,在给出逻辑运算结果时,以数值1代表“真”,以0代表“假”,但在判断一个逻辑量是否为“真”时,采取的标准是: 如果其值是0就认为是“假”,如果其值是非0就认为是“真”。例如: (1) 若a=4,则!a的值为0。因为a的值为非0,被认作“真”,对它进行“非”运算,得“假”,“假”以0代表。 (2) 若a=4,b=5,则a & b的值为1。因为a和b均为非0,被认为是“真” 。 (3) a,b值同前,a-b|a+b的值为1。因
26、为a-b和a+b的值都为非零值。 (4) a,b值同前,!a | b的值为1。 (5) 4 & 0 | 2 的值为1。,if语句是用来判定所给定的条件是否满足,根据判定的结果(真或假)决定执行给出的两种操作之一。,3.7 选择结构和语句,1. (表达式)语句 例如: if(xy) couty) coutx; else couty; 见图3.5(b)。,3.7.1 语句的3种形式,图3.5,3. if(表达式1) 语句1 else if(表达式2) 语句2 else if(表达式3) 语句3 else if(表达式m) 语句m else 语句n 流程图见图3.6。 例如: if (number5
27、00) cost=0.15; else if(number300) cost=0.10; else if(number100) cost=0.075; else if(number50) cost=0.05; else cost=0;,图3.6,说明: (1) 从图3.5和图3.6可以看到: 3种形式的if语句都是由一个入口进来,经过对“表达式”的判断,分别执行相应的语句,最后归到一个共同的出口。这种形式的程序结构称为选择结构。在C+中if语句是实现选择结构主要的语句。 (2) 3种形式的if语句中在if后面都有一个用括号括起来的表达式,它是程序编写者要求程序判断的“条件”,一般是逻辑表达式或
28、关系表达式。 (3) 第2、第3种形式的if语句中,在每个else前面有一分号,整个语句结束处有一分号。 (4) 在if和else后面可以只含一个内嵌的操作语句(如上例),也可以有多个操作语句,此时用花括号“”将几个语句括起来成为一个复合语句。,例3.6 求三角形的面积。 #include #include /使用数学函数时要包含头文件cmath #include /使用I/O流控制符要包含头文件iomanip using namespace std; int main( ) double a,b,c;coutabc;if (a+bc ,运行情况如下: please enter a,b,c:2
29、.45 3.67 4.89 area=4.3565 变量s和area只在复合语句内用得到,因此在复合语句内定义,它的作用范围为从定义变量开始到复合语句结束。如果在复合语句外使用s和area,则会在编译时出错,系统认为这两个变量未经定义。将某些变量局限在某一范围内,与外界隔离,可以避免在其他地方被误调用。,在if语句中又包含一个或多个if语句称为if语句的嵌套。一般形式如下: if( ) if( )语句1 else 语句2 内嵌if else if( )语句3 else 语句4 内嵌if 应当注意if与else的配对关系。else总是与它上面最近的、且未配对的if配对。假如写成,3.7.2 语句
30、的嵌套,if( ) if( )语句1 else if( )语句2 else 语句3 内嵌if 编程序者把第一个else写在与第一个if(外层if)同一列上,希望else与第一个if对应,但实际上else是与第二个if配对,因为它们相距最近,而且第二个if并未与任何else配对。为了避免误用,最好使每一层内嵌的if语句都包含else子句(如本节开头列出的形式),这样if的数目和else的数目相同,从内层到外层一一对应,不致出错。,如果if与else的数目不一样,为实现程序设计者的企图,可以加花括号来确定配对关系。例如: if( ) if ( ) 语句1 /这个语句是上一行if语句的内嵌if el
31、se 语句2 /本行与第一个if配对 这时 限定了内嵌if语句的范围, 外的else不会与 内的if配对。关系清楚,不易出错。,若在if语句中,当被判别的表达式的值为“真”或“假”时,都执行一个赋值语句且给同一个变量赋值时,可以用简单的条件运算符来处理。例如,若有以下if语句: if (ab) max=a; else max=b; 可以用条件运算符(? :)来处理: max=(ab)?a:b; 其中“(ab)?a:b”是一个“条件表达式”。它是这样执行的:如果(ab)条件为真,则条件表达式的值就取“?”后面的值,即条件表达式的值为,否则条件表达式的值为“:”后面的值,即b。,3.8 条件运算符
32、和条件表达式,条件运算符要求有3个操作对象,称三目(元)运算符,它是C+中惟一的一个三目运算符。条件表达式的一般形式为 表达式1 ? 表达式2 表达式3 条件运算符的执行顺序是:先求解表达式1,若为非0(真)则求解表达式2,此时表达式的值就作为整个条件表达式的值。若表达式1的值为0(假),则求解表达式3,表达式3的值就是整个条件表达式的值。“max=(ab)?a:b” 的执行结果是将条件表达式的值赋给max。也就是将a和b二者中的大者赋给max。条件运算符优先于赋值运算符,因此上面赋值表达式的求解过程是先求解条件表达式,再将它的值赋给max。,条件表达式中,表达式1的类型可以与表达式2和表达式
33、3的类型不同。如 x? ab 如果已定义x为整型变量,若x=0,则条件表达式的值为字符b的ASCII码。表达式2和表达式3的类型也可以不同,此时条件表达式的值的类型为二者中较高的类型。如有条件表达式xy?1:1.5,如果xy,则条件表达式的值为1.5,若xy,值应为1,由于C+把1.5按双精度数处理,双精度的类型比整型高,因此,将1转换成双精度数,以此作为表达式的值。,例3.7 输入一个字符,判别它是否为大写字母,如果是,将它转换成小写字母;如果不是,不转换。然后输出最后得到的字符。 #include using namespace std; int main( ) char ch;cinch
34、;ch=(ch=A ,switch语句是多分支选择语句,用来实现多分支选择结构。 它的一般形式如下: switch(表达式)case 常量表达式1:语句1case 常量表达式2:语句2.case 常量表达式n:语句ndefault:语句n+1,3.9 多分支选择结构和switch 语句,例如,要求按照考试成绩的等级打印出 百分制分数段,可以用switch语句实现: switch(grade)case A: cout85100n;case B: cout7084n;case C: cout6069n;case D: cout60n;default : couterrorn; 说明: (1) sw
35、itch后面括号内的“表达式”,允许为任何类型。 (2) 当switch表达式值与某一个case子句中的常量表达式的值相匹配时,执行此case子句中的语句,若所有的case子句中的值都不能与switch表达式的值匹配,就执行default子句的内嵌语句。,(3) 每一个case表达式的值必须互不相同,否则就会出现互相矛盾的现象(对表达式的同一个值,有两种或多种执行方案)。 (4) 各个case和default的出现次序不影响执行结果。例如,可以先出现“default:”,再出现“case D:”,然后是“case A:”。 (5) 执行完一个case子句后,流程控制转移到下一个case子句继续
36、执行。“case常量表达式”只是起语句标号作用,并不是在该处进行条件判断。在执行switch语句时,根据switch表达式的值找到与之匹配的case子句,就从此case子句开始执行下去,不再进行判断。例如,上面的例子中,若grade的值等于A,则将连续输出:,851007084606960error 因此,应该在执行一个case子句后,使流程跳出switch结构,即终止switch语句的执行。可以用一个break语句来达到此目的。将上面的switch结构改写如下: switch(grade)case A: cout85100n;break;case B: cout7084n;break;cas
37、e C: cout6069n;break;case D: cout60n;break;default : couterrorn;break;,最后一个子句(default)可以不加break语句。 如果grade的值为B,则只输出“7084”。 流程图如下。,在case子句中虽然包含一个以上执行语句,但可以不必用花括号括起来,会自动顺序执行本case子句中所有的执行语句。 (6) 多个case可以共用一组执行语句,如.case A: case B: case C: cout60n;. 当grade的值为A、B或C时都执行同一组语句。,例3.8 编写程序,判断某一年是否为闰年。 #include
38、 using namespace std; int main( ) int year;bool leap;coutyear; /输入年份if (year%4=0) /年份能被4整除if(year%100=0) /年份能被4整除又能被100整除if (year%400=0) /年份能被4整除又能被400整除leap=true; /闰年,令leap=true(真)else leap=false; /非闰年,令leap=false(假)else /年份能被4整除但不能被100整除肯定是闰年leap=true; /是闰年,令leap=true,3.10 编写选择结构的程序,else /年份不能被4整除
39、肯定不是闰年leap=false; /若为非闰年,令leap=falseif (leap)coutyear is ; /若leap为真,就输出年份和“是”elsecoutyear is not ; /若leap为真,就输出年份和“不是”cout a leap year.endl; /输出“闰年”return 0; 运行情况如下: 20052005 is not a leap year. 19001900 is npt a leap year.,例3.9 运输公司对用户计算运费。路程(s)越 远,每公里运费越低。标准如下: s250km 没有折扣250s500 2折扣500s1000 5折扣10
40、00s2000 8折扣2000s3000 10折扣3000s 15折扣 设每公里每吨货物的基本运费为p(price的缩写),货物重为w(wright的缩写),距离为,折扣为d(discount的缩写),则总运费f(freight的缩写)的计算公式为 f = p * w * s * (1 - d),图3.8,据此写出程序如下: #include using namespace std; int main( ) int c,s;float p,w,d,f;coutpws;if(s=3000) c=12;else c=s/250;switch (c) case 0:d=0;break;case 1:
41、d=2;break;case 2:case 3:d=5;break;case 4:,case 5:case 6:case 7:d=8;break;case 8:case 9:case 10:case 11:d=10;break;case 12:d=15;break;f=p*w*s*(1-d/100.0);coutfreight=fendl;return 0; 运行情况如下: please enter p,w,s:100 20 300 freight=588000,在人们所要处理的问题中常常遇到需要反复执行某一操作的情况。这就需要用到循环控制。许多应用程序都包含循环。顺序结构、选择结构和循环结构
42、是结构化程序设计的3种基本结构,是各种复杂程序的基本构造单元。因此程序设计者必须熟练掌握选择结构和循环结构的概念及使用方法。,3.11 循环结构和循环语句,while语句的一般形式如下: while (表达式) 语句 其作用是: 当指定的条件为真(表达式为非0)时,执行while语句中的内嵌语句。其流程图见图3.9。其特点是:先判断表达式,后执行语句。while循环称为当型循环。图3.9,3.11.1 用while语句构成循环,例3.10 求1+2+3+100。 用流程图表示算法,见图3.10。 根据流程图写出程序: #include using namespace std; int main
43、( ) int i=1,sum=0;while (i=100) sum=sum+i;i+; coutsum=sumendl; 运行结果为 sum=5050,需要注意: (1) 循环体如果包含一个以上的语句,应该用花括号括起来,以复合语句形式出现。如果不加花括号,则while语句的范围只到while后面第一个分号处。 (2) 在循环体中应有使循环趋向于结束的语句。,图3.10,do-while语句的特点是先执行循环体,然后判断循环条件是否成立。其一般形式为 do 语句while (表达式); 它是这样执行的:先执行一次指定的语句(即循环体),然后判别表达式,当表达式的值为非零(“真”) 时,返回
44、重新执行循环体语句,如此反复,直到表达式的值等于0为止,此时循环结束。可以用图3.11表示其流程。,3.11.2 用do-while语句构成循环,图3.11 图3.12,例3.11 用do-while语句求1+2+3+100。 先画出流程图,见图3.12。 可编写出下面的程序: #include using namespace std; int main( ) int i=1,sum=0;do sum=sum+i;i+;while (i=100);coutsum=sumendl;return 0; ,运行结果与例3.10相同。 可以看到:对同一个问题可以用while语句处理,也可以用dowhi
45、le语句处理。dowhile语句结构可以转换成while结构。,C+中的for语句使用最为广泛和灵活,它完全可以代替while语句。 for语句的一般格式为 for(表达式1;表达式2;表达式3) 语句 (1) 先求解表达式1。 (2) 求解表达式2,若其值为真(值为非0),则执行for语句中指定的内嵌语句,然后执行下面第(3)步。若为假(值为0),则结束循环,转到第(5)步。 (3) 求解表达式3。 (4) 转回上面第(2)步骤继续执行。 (5) 循环结束,执行for语句下面的一个语句。,3.11.3 用for语句构成循环,可以用图3.14来表示for语句的执行过程。图3.14,for语句最
46、简单的形式也是最容易理解的格式如下: for(循环变量赋初值;循环条件;循环变量增值) 语句 例如 for(i=1;i=100;i+) sum=sum+i; 它的执行过程与图3.10完全一样。它相当于以下语句:i=1;while(i=100)sum=sum+i;i+; 显然,用for语句简单、方便。,说明: (1) for语句的一般格式中的“表达式1”可以省略,此时应在for语句之前给循环变量赋初值。 (2) 如果表达式2省略,即不判断循环条件,循环无终止地进行下去。也就是认为表达式2始终为真。 (3) 表达式3也可以省略,但此时程序设计者应另外设法保证循环能正常结束。 (4) 可以省略表达式1和表达式3,只有表达式2,即只给循环条件。 (5) 3个表达式都可省略。 (6) 表达式1可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其他表达式。,(7) 表达式一般是关系表达式(如i=100)或逻辑表达式(如ab & xy),但也可以是数值表达式或字符表达式,只要其值为非零,就执行循环体。 C+中的for语句比其他语言中的循环语句功能强得多。可以把循环体和一些与循环控制无关的操作也作为表达式1或表达式3出现,这样程序可以短小简洁。但过分地利用这一特点会使for语句显得杂乱,可读性降低,建议不要把与循环控制无关的内容放到for语句中。,