【文档说明】C程序设计课件_第3章-C语言程序的控制结构解析.ppt,共(95)页,386.502 KB,由小橙橙上传
转载请保留链接:https://www.ichengzhen.cn/view-44465.html
以下为本文档部分文字说明:
第3章C语言程序的控制结构本章导读本章包括知识点:算法的描述方法数据的输入输出函数调用格式if语句及switch语句的使用3种循环结构break、continue和goto语句的作用常用算法:如递推法、穷举法等C程序的基本风格3
.1算法3.1.1算法的概念3.1.2算法的表示方法3.1.1算法的概念著名的计算机科学家沃思(NikiklausWirth)曾经提出过:数据结构+算法=程序数据结构(datastructure):即对数据的描述和组织
形式。算法(algorithm):对操作或行为的描述,即操作步骤。广义地说,算法就是做某一件事的步骤或程序。计算机解题的算法大致包括这两大类算法:非数值运算算法和数值运算算法。算法特性:①有穷性。算法的步骤必须是有限的,每个步骤都在有限的时间内做完,执行有限个步骤后终止。②确定性。算法中每一步骤
都必须有明确定义,不允许有模棱两可的解释,不允许有多义性。例如:“如果成绩大于等于90分,则输出A;如果成绩小于等于90分,则输出B”,当成绩为90分时,既会输出A,又会输出B,这就产生了不确定性。③有效性。算法的每一步操作都应该能有效执行。如一
个数被0除就是无效不可行的,应避免。算法特性④没有输入或有多个输入。例如:求1+2+3+…+100时,不需要输入任何信息就能求出结果;而要求1+2+3+…+n时,必须从键盘输入n的值,才能求出结果。⑤有一个或多个输出。算法的目的
是为了求解,“解”就是算法的输出。没有输出的算法是没有意义的。3.1.2算法的表示方法常用方法有:自然语言、传统流程图、NS流程图、伪代码等1.用自然语言表示算法自然语言就是人们日常使用的语言,可以是汉语、英语或其他语言。用自然语言表示算法,通俗易懂,但文字冗长,在表达上
不够严格,引起理解上的歧义性,不易转化为程序,描述复杂的算法不很方便。因此,除了很简单的问题外,一般不用自然语言描述算法。用自然语言表示的求1+2+3+…+6的算法如下:算法1:S1:计算1+2得到3;S2:将第一步中的运算结果3与3相加得到6;S3:将第二步中的运算结果6与4相
加得到10;S4:将第三步中的运算结果10与5相加得到15;S5:将第四步中的运算结果15与6相加得到21。算法2:S1:定义循环变量i=1,用于保存和的变量s,并置初值为0;S2:判断i的值是否小于等于6,若是则执行S3,否则跳转到S4执行;
S3:将i的值累加到s,然后变量i自身加1,转到S2执行;S4:输出s的值。算法1是最原始的方法,最为繁琐,步骤较多,当加数较大时,比如1+2+3+…+10000,再用这种方法是行不通的;算法2是比较简单的算法,且易于在计算机上执行操作。2.用传统流程图表示算法流程图是一个描述程序的控制流
程和指令执行情况的有向图,用流程图表示算法,直观形象,易于理解。美国国家标准化协会(ANSI)规定了一些常用符号如图所示用传统流程图描述计算1+2+3+…+6的算法3.用NS结构化流程图表示算法1973年美国学者I.Nassi和B.Schn
eiderman提出了一种新型流程图—NS结构化流程图,这种流程图一方面取消了带箭头的流程线,这样算法被迫只能从上到下顺序执行,避免了算法流程的任意转向,适于结构化程序设计;另一方面,这种流程图节省篇幅,因而很受欢迎。用NS流程图描述的计算1+2+3+…+6的算法4
.用伪代码表示算法伪代码使用介于自然语言和计算机语言之间的文字和符号来描述算法。它使用起来灵活,无固定格式和规范,无图形符号,只要写出来自己或别人能看懂就行,由于它与计算机语言比较接近,便于向计算机语言算法(即程序)过渡。用伪代码描述的1+2+3+…+6算法如
下:begin/*算法开始*/1=>i0=>swhilei≤6{s+i=>si+1=>i}printsend/*算法结束*/在程序设计中读者可根据需要和习惯任意选用。3.2C语句的分类C语言的语句可分为5大类:控制语句函数调用语句表达式语句复合语句
空语句1.控制语句控制语句用来实现对程序流程的选择、循环、转向和返回等进行控制。C语言中共有9种控制语句,包括12个关键字,可以分为以下几类:选择语句:if…else和switch(包括case和default)。循环语句:for、whi
le和do…while。转向语句:continue、break和goto。返回语句:return。本章的3.5、3.6和3.7中将陆续介绍这些控制语句。2.函数调用语句函数调用语句是由一个函数调用加一个分号构成的语句。它的一般形式是:函数名(实参表);例如:print
f(“ThisisaCProgram”);/*用于输出双引号中的字符串*/c=getchar();/*用于从键盘读入一个字符*/m=max(a,b,c);/*用于求取a、b、c三者之间的最大值并将结果赋给m*/3.表达式语句由一个表达式加上一个分号构成。如:A+
+;x=1;p+=q*4+5;y=4>2?6:1;用一对花括号,把若干条语句括起来,就形成了一条复合语句。形式如下:4.复合语句复合语句的形式为:{语句1;语句2;…语句n;}例如:{z=x+y;z++;u=z/100;printf(“%f”,u);}花括号中的语句,可以是简单语句
、空语句、复合语句、流程控制语句,所有这些语句括在一起,在语法上看成是一条语句,执行时顺序执行花括号中的每条语句。复合语句多用于流程控制语句中。5.空语句仅仅以分号“;”作为标识。空语句的形式为:;/*空语句*/空语句本身没有实际功能,只是表示什么操作都不做。设置空语句的目的,
一是在未完成的程序设计模块中,暂时放一条空语句,留待以后对模块逐步求精实现时再增加语句;二是实现空循环等待;三是实现跳转目标点等。例如:intmax(inta,intb)/*求两个整数的最大值*/{;
/*此处的空语句表示在以后添加内容,保证当前的程序正常运行*/}例如:实现空循环while(getchar()!=’\n’);/*此语句表示只要从键盘输入的字符不是回车键则重新输入*/例如:实现跳转到目标点inti=0,sum=0;ex:;sum+=i++;if(x<100)goto
ex;…空语句出现的位置是有限制的。预处理命令、函数头和花括号“}”之后都不允许出现空语句。注意3.3输入和输出语句3.3.1字符的输入和输出3.3.2格式化输入和输出C语言不提供输入和输出语句,输入和输出通过调用C的标准库函数来实现
。C的标准函数库中提供许多用于标准输入和输出的库函数(附录D),使用这些标准输入和输出库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。在调用标准输入输出库函数时,文件开头应有以下预编译命令:#include<stdio.h>或#include“
stdio.h”其中,h为head之意,std为standard之意,i为input之意,o为output之意。3.3.1字符的输入和输出计算机的控制台是键盘和显示器,从控制台输入和输出字符的最简单的函数是getchar()和putchar()。1.getchar函数使用格式:变量=get
char();功能:从键盘读入一个字符,返回该字符的ASCII值,可以将该结果赋值给字符变量或整型变量,并自动将用户击键结果回显到屏幕上。2.putchar函数使用格式:putchar(变量);功能:把字符写到屏幕的当前光标位置。例3.1演示如何使用getchar()和putch
ar()函数。#include<stdio.h>main(){charc;c=getchar();/*从键盘读入一个字符,按回车键结束输入,该字符被存入变量c*/putchar(c);}①getchar函数无参数,它从标准输入设备(键盘)上
读入一个字符,直到输入回车键才结束,回车前的所有输入字符都会逐个显示在屏幕上。函数值为从输入设备输入的第1个字符,空格、回车和Tab都能被读入。②putchar函数的参数是待输出的字符,这个字符可以是可
打印字符,也可以是转义字符。例如:putchar('\x42');/*输出字母B*/putchar(0x42);/*直接用ASCII码值输出字母B*/注意3.3.2格式化输入和输出前面的getchar和putcha
r函数形式简单,使用方便,但只能输入输出一个字符,且不能定制输入输出格式。格式化输入输出函数既能输入输出各种类型的数据,又能定制输入输出格式。例3.2从屏幕上输出一个整数。#include<stdio.h>main(){inta,b;
a=10;b=20;printf("outputaandb:");/*输出双引号中的字符串*/printf("a=%d,b=%d\n",a,b);/*输出a和b的值*/}输出结果是:outputaandb:a=1
0,b=201.printf函数格式:printf(格式控制字符串);或printf(格式控制字符串,输出表列);功能:向计算机系统默认的输出设备输出若干个任意类型的数据。例如:格式转换说明符printf("a=%d,b=%d\n",a,b
);普通字符输出表列一般情况下,格式控制字符串包括两种数据,一种是普通字符,这些字符在输出时照原样输出;另一种是格式转换说明符,用于控制要输出的内容以何种方式进行输出显示,格式转换说明符由“%”开始,并以一个格式字符结束。表3-1printf函数的格式转换说明符字符含义示例输出
结果d(或i)十进制整数inta=65;printf(“%d”,a);65u十进制无符号整数inta=65000;printf(“%u”,a);65000o八进制无符号整数inta=65;printf(“%o”,a);101x(或X)十六进制无符号整数inta=65;printf(“
%x”,a);41c单一字符inta=65;printf(“%c”,a);As字符串printf(“%s”,”Hello”);Hellof小数形式的浮点小数printf(“%f”,314.56);314.560000e(或E
)指数形式的浮点小数printf(“%e”,314.56);3.145600e+002g(或G)e和f中较短的一种printf(“%g”,314.56);314.56%百分号本身printf(“%%”);%说明:①“输出表列”是需要输出的一些数据。可以是表达式,各个数据之间用逗号隔开
。以下的printf函数都是合法的:printf("Iamastudent.\n");printf("%d",3+2);注意:输出数据的数据类型与格式转换说明符必须顺序匹配,否则会引起输出错误。如:printf("%d,%
f",3.89,6);错误!②一般情况下,格式转换说明符与输出项个数相同。如果格式转换说明符的个数大于输出项的个数,则多余的格式将输出不定值。如果格式转换说明符的个数小于输出项的个数,则多余的输出项不输出。例3.3有以下程序#include<stdio.h>main(){inta=666,b
=888;printf("%d\n",a,b);}程序的输出结果是()。A)错误信息B)666C)888D)666,888思考:如果将输出语句改为printf(“%d,%d\n”,a);输出结果会怎样?格式转换
说明符的完整形式如下:%-0#m.nl或h格式字符修饰字符含义英文字母l修饰d,u,o,x时,用于输出long型数据修饰f,e,g时,用于输出longdouble型数据英文字母h修饰d,o,x时,用于输出short型数据
最小域宽m指定输出项输出时所占列数,数据长度<m,左边补空格;否则按实际宽度输出显示精度.n对于实数,指定小数位数(四舍五入)对于字符串,指定从字符串左侧开始截取的子串字符个数-输出数据在域内左对齐(默认右对齐)+指定在有符号数的正数前加正号
(+)0输出数值时,指定在左边不使用的空位置自动填0#在八进制和十六进制数前显示前导符0,0x例3.4printf函数修饰符的使用。#include<stdio.h>main(){inta=123;floaty=456.78;charch='A';chars[]="P
rograming";/*s为字符数组*/printf("%7d,%-4d,%04d\n",a,a,a);printf("%f,%8f,%8.1f,%.2f,%.2e\n",y,y,y,y,y);printf("%3c
\n",ch);printf("%s\n%12s\n%8.5s\n%2.5s\n%.3s\n",s,s,s,s,s);}程序输出结果说明:在VisualC++中,调用printf函数时,float类型的参数是先转化为double类型再传递的,所以%f可以输出float和double两种
类型的数据,不必用%lf输出double类型的数据。2.scanf函数格式:scanf(格式控制字符串,地址表列);功能:从标准输入设备(键盘)输入若干个任意类型的数据。例如:scanf("%d,%f”,&a,&b);地址表列格式控制字符串分隔符表3-3scanf函数的格式转换说明符字
符含义d或i输入十进制整数u输入无符号十进制整数o输入八进制整数x输入十六进制整数c输入一个字符,空白字符(包括空格、回车、制表符)也作为有效字符输入s输入字符串,遇到第一个空白字符(包括空格、回车、制表符)时结束f或e输入实数,以小数或指数形式输入均可%输入一个%地址表列是由若干变量的地址
组成的列表,参数之间用逗号隔开。函数scanf要求必须指定用来接收数据的地址,否则,虽然编译程序不会出错,但会导致数据不能正确地读入指定的内存单元。对普通变量而言,可以在变量前使用“&”符号,用于取变量的地
址,而对于指针变量而言,直接使用指针变量名称即可。表3-4scanf函数的修饰符修饰字符含义英文字母l修饰d,i,u,o,x时,用于输入long型数据修饰f,e时,用于输入double型数据英文字母h修饰d,i,o,x时,用于输入short型数据域宽m指定输入数据的宽度(列
数),系统自动按此宽度截取所需数据忽略输入修饰符*抑制符,表示对应的输入项在读入后不赋给相应的变量注:scanf函数没有精度.n修饰符,即用scanf函数输入实型数据时不能规定精度。输入数据的分隔符的指定:①一般以空格、TAB或回车符作为分隔符(在格式控制符之间为空格、TAB或无任何符号时);
②其他字符作为分隔符:格式控制字符串中两个格式控制符之间的字符为上述三种字符以外的字符时,输入数据时要原样输入。例如,输入语句“scanf(“%d,%d”,&a,&b);”,要想在输入数据后使a=3,b=4,则
应输入“3,4”。例3.5格式输入输出的使用。#include<stdio.h>main(){inta,b,k;floats,f;charc1,c2,m[10];scanf("%d,%d,%f,%s",&a,&b,&s,m);/*m是数组名,表示地址*/sc
anf("%3d%*4d%f",&k,&f);scanf("%*c%3c%2c",&c1,&c2);printf("a=%d,b=%d,s=%f,m=%s\n",a,b,s,m);printf("k=%d,f=%f,c1=%c,c2=%c\n",k,f,c1,c2);}程序运行时的输入
输出结果注意①从键盘输入数据的个数应该与函数中输入表列的项数相同,当两者不相同时作如下处理:如果输入数据个数少于scanf函数要求的个数时,函数将等待输入,直到满足要求或遇到非法字符为止。如果输入数据个数多于scanf函数要求的个数时,多余的数据将留在缓冲区作为下一次输入操作的输入
数据。②在输入数据时,遇到以下情况时认为该数据结束。遇到空格,或按回车键或按TAB键;按指定的宽度结束,如“%3d”,只取3列;遇到非法输入。3.4顺序程序控制结构顺序结构是结构化程序设计的三种基本结构中最简单的一种程序组织结构,其特点是完全
按照语句出现的先后顺序依次执行。BAAB(a)传统流程图(b)NS流程图程序自上而下执行,先执行A块,再执行B块。顺序结构的程序主要由4部分组成:①变量说明部分。②数据输入部分。③运算部分。④运算结果输出部分。例3.
6将任意小写字母转换为对应的大写字母并输出。#include<stdio.h>main(){charc;c=getchar();c=c-32;putchar(c);}程序运行时,若输入:h↙则输出:H思考:如何判断输入的字符是否为小写字母?(将在3.5中讲解)例3.7从键
盘输入两个变量的值,交换这两个变量的值,并输出。分析:假如我们将输入的两个变量定义为x和y,如果通过“x=y;y=x;”来实现交换,则当执行“x=y;”时,将y的值复制给x,此时x和y的值相等,x原来的
值丢失,再执行“y=x;”时,将新的x值复制给y,结果x和y的值相等,都为原来y的值。为了不使x原来的值丢失,必须在执行“x=y;”之前,先把x的值放到一个临时变量(temp)中保存起来,在执行了“x=y;后”,再把保存在临时变量中的值赋给y(通过“y=temp;”来实
现)。程序代码:#include<stdio.h>main(){intx,y,temp;scanf("%d,%d",&x,&y);printf("Beforechange:x=%dy=%d\n",x,y);temp=x;x=y;y=temp;prin
tf("afterchange:x=%dy=%d\n",x,y);}思考:如果不用临时变量,能否使两个变量得到交换呢?例3.8从键盘任意输入一个三位数,要求输出这个数的逆序数。如:输入123,输出321。分析:要输出逆序数,则要将原数的个位、十位和百
位数分离出来,再用“个位*100+十位*10+百位”求出逆序数。个位数字可用对10求余得到,如123%10=3;最高位百位数字可用对100整除得到,如123/100=1;中间位的数字既可通过将其变换为最高位再整除的
方法得到,如(123-1*100)/10=2;也可通过将其变换为最低位再求余得到,如(123/10)%10=2。程序源代码如下:#include<stdio.h>main(){intx,y,b0,b1,b2;/*变量声明*/printf("Plea
seenteranintegerx:");/*提示用户输入一个整数*/scanf("%d",&x);/*输入一个整数*/b0=x%10;/*求最低位*/b1=(x/10)%10;/*求中间位*/b2=x/100;/*求最高位*/y=b0*100+b1
*10+b2;/*求逆序数*/printf("y=%d\n",y);/*输出逆序数*/}程序的运行结果如下:Pleaseenteranintegerx:123↙y=321思考:是否还有其他方法分离个位
、十位和百位数?3.5选择程序控制结构对于要先做判断再选择的问题就要使用选择结构(也称为分支结构)。选择结构的执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。如:在数学中,要计算x的绝对值,根据绝对值定义,当x>=0时,其绝对值为x,而x<0时其绝对值是为
-x。选择结构分支条件通常用关系表达式或逻辑表达式来表示,实现程序流程的语句由C语言的if语句或switch语句来完成图3-8选择结构流程图图3-8表示,当条件P为真(成立)时执行A框,否则执行B框。无论P是否成立,只能执行A框或
B框之一,不可能既执行A框又执行B框。无论走哪条路径,在执行A框或B框之后,都脱离本选择结构。3.5.1if语句1.单分支结构2.双分支结构3.多分支结构1.单分支结构if形式:if(表达式)语句S图3-9单分支结构的流程图执行过程:系统首先计
算表达式的值,如果表达式结果不为0,则执行语句S,否则跳过语句S,继续执行其后的其他语句。说明:①“if”是C语言的关键字;“表达式”可以任意合法的C语言表达式,可以是关系表达式或逻辑表达式,也可以是任意的数值类型(包括整型、实型、字符型等);表达式两侧的括号不能省略。②语句S可以
是一条语句,也可以是任意合法的复合语句,其位置比较灵活,可以直接出现在if同一行的后面,也可以出现在if的下一行。例3.9写出以下程序执行后的输出结果#include<stdio.h>main(){inta=4,b=3,c=5,t=0;if(a<b)t=a;a=b;b=t;if(a<c
)t=a;a=c;c=t;printf("%d%d%d\n",a,b,c);}输出结果为:503分析:程序第一行在定义a、b、c、t四个变量的同时进行了初始化。接下来第一个if语句的表达式a<b为假(0),if其后的语句“t=a;”不执行,值得注意的是“a=b;b=t;”不属于if的语句,将被
执行,执行后a值为3,b值为0;然后第二个if语句的表达式a<c为真,则执行语句“t=a;”,t值变为3,接着执行“a=c;”,a值变为5,再接着执行“c=t;”,c值变为3;因此,输出结果为:503。例3.10计算并输出一个整数的绝对值。分析:计算一个整数
的绝对值的关键就是判断该数是否小于0。#include<stdio.h>main(){intx,y;scanf("%d",&x);/*输入一个整数*/y=x;/*x大于等于0时,y=x*/if(x<0)y=-x;/*若x<0成立,y=-x*/printf("y=%d\n",y);}2.双分
支结构if-else形式:if(表达式)语句S1else语句S2图3-10双分支结构的流程图执行过程:系统首先计算表达式的值,如果表达式结果不为0,则执行语句S1,否则,执行语句S2。选择结构执行完成后继续执行其后的其他语句。例
如:求两个数中的较大值,可用下面的语句:if(a>b)max=a;elsemax=b;将例3.10用双分支结构实现,程序代码如下:#include<stdio.h>main(){intx,y;scanf("%d",&x);/*输入一个整数*/if(x<0)y=-x;/*若x<0成立,y=
-x,否则y=x*/elsey=x;printf("y=%d\n",y);}例3.11从键盘读入一个字符,以与原来不同的形式进行输出。分析:该题的意图是实现英文字符的输入输出,所谓与与原来不同的形式是指原来输入的是小写字母,则转换为对应的大写字母并输出;原来输入的
是大写字母则转换为对应的小写字母并输出。程序实现的步骤是:①从键盘输入一个英文字符;②判断该英文字符的大小写,并转换成对应的字母;③输出转换后的英文字符。该题的关键问题是怎样将判断字符的大小写状态和实现转换。有两种方式实现:一种是根据ASCII码进行判断和转换,小写
字母比对应的大写字母的ASCII码大32。另一种方式是利用字符处理函数isupper(ch)判断ch是否为大写字母,是则返回1,否则返回0;islower(ch)函数判断ch是否为小写字母,是则返回1,否则返回0;toupper(ch)函数将ch
转换为大写,tolower(ch)函数将ch转换为小写。注意,使用这四个函数需要包含头文件ctype.h。用第一种方式实现的程序如下:#include<stdio.h>main(){charch;ch=getchar();/*从键盘输入一个英文字符*/if(ch>='a'&&ch<
='z')/*判断ch是否为小写字母*/ch=ch-32;/*ch为小写字母,将其转换为大写*/elsech=ch+32;/*ch为大写字母,将其转换为小写*/putchar(ch);/*输出ch*/}运行时,输入:a↙输出:A思考:用字符处理函数怎样实现程序?3
.多分支结构if-else-if形式:if(表达式1)语句S1elseif(表达式2)语句S2…elseif(表达式n)语句Snelse语句Sn+1图3-11双分支结构的流程图执行过程:if-else-if结构实际上是由多个if-else结构组合而成的,系统
首先计算表达式1,其值为真(不为0)时,执行语句S1;否则,计算表达式2,其值为真(不为0)时,执行语句S2;…如果if后的所有表达式都不为真,则执行语句Sn+1,并结束整个分支结构。选择结构执行完成后继续执行其
后的其他语句。例3.12从键盘输入x的值,并通过如下的数学关系式求出相应的y值。010001xxxy分析:该题的意图是根据输入的x值,判断x所属的区间,求出y值并输出。程序实现的步骤是:①从键盘输入一个数;②判断x所属的
区间,求出y值;③输出结果。#include<stdio.h>main(){intx,y;scanf("%d",&x);if(x<0)y=-1;elseif(x==0)y=0;elsey=1;printf("y=%d\n",y);
}注意:在表示相等条件时,必须用“==”,不能用“=”例3.13根据输入的成绩等级打印出评语,等级与评语的对应关系如下表:等级评语4Excellent3Good2Average1Poor0Failing分析:该题通过输入成绩的等级(0~4级),转换为对
应的评语,是典型的多分支结构,可以用if-else-if结构实现。具体实现步骤为:①输入成绩等级的数字;②对输入的数字进行判断,得到对应的评语;③输出结果。#include<stdio.h>main(){intgrade;printf("Pleaseinputgrade:");sc
anf("%d",&grade);if(grade==4)printf("Excellent");elseif(grade==3)printf("Good");elseif(grade==2)printf("Average");elseif
(grade==1)printf("Poor");elseif(grade==0)printf("Failing");elseprintf("Illegalgrade");}4.if语句的嵌套if语句的嵌套是指if或else子句中又包
含一个或多个if语句。内层的if语句既可以嵌套在if子句中,也可以嵌套在else子句中。内嵌if语句的一般形式如下:if(表达式1)if(表达式2)语句1else语句2elseif(表达式3)语句3else语句4嵌套的if语句的几种变化形式①只在if
子句中嵌套if语句,形式如下:if(表达式1)if(表达式2)语句1else语句2else语句3②只在else子句中嵌套if语句,形式如下:if(表达式1)语句1elseif(表达式2)语句2else语句3③不
断在else子句中嵌套if语句形成多层嵌套,形式如下:if(表达式1)语句3语句1…elseif(表达式n-1)if(表达式2)语句n-1语句2elseelse语句nif(表达式3)可以用if-else-if语句形式表示,看起来层次比较分明。if(表达式1)…语句1…elseif(表达式2)els
eif(表达式n-1)语句2语句n-1elseif(表达式3)else语句3语句n例3.14从键盘输入三个正整数,找出其中的最大数,并输出这个数。流程图如下:#include<stdio.h>main(){inta,b,c,max;scanf("%d%d%d",&a,&b,&c);if(a>b
)if(a>c)max=a;elsemax=c;elseif(b>c)max=b;elsemax=c;printf("max=%d",max);}注意①注意if与else的配对关系。内嵌结构中,else总是与它上面最近的、未
配对的if配对,组成一对if-else语句。②如果if与else的数目不一样,为了避免在if与else配对时出错,建议读者使用“{}”来限定内嵌if语句的范围。如下形式的嵌套语句:if(表达式1){if(表达式2)语句1}else语句2这里,“{}”限定了内嵌if语句的范围
,因此else与第一个if配对。思考:如果没有“{}”,else与哪个if配对?例3.15设变量a、b、c、d和y都已正确定义并赋值。若有以下if语句if(a<b)if(c==d)y=0;elsey=1;该语句所表
示的含义是()。A)B)C)D)badcbay10且dcbadcbay且且10dcbadcbay且且10dcdcbay10且3.5.2switch语句当问
题的分支较多(一般大于3个),用if-else-if结构解决时由于分支过多,结构冗长,程序逻辑关系不清晰,通常使用开关语句(switch语句)来简化程序设计。开关语句就像多路开关一样,使程序控制流程形成多个分支,根据一个表达式可能产生的不同结果值,选择其中的
一个或几个分支语句去执行。因此,它常用于各种分类统计、菜单等程序设计。switch语句的一般形式switch(表达式){case常量表达式1:语句1;break;case常量表达式2:语句2;break;…case常量表达式n:语句n;break;d
efault:语句n+1;break;}switch结构流程图执行过程:①计算switch后圆括号内表达式的值,然后用该值逐个与case后的常量表达式值进行比较。当找到相匹配的值时,就执行该case后面的语句。若所有case中的常量表达式的值都没有与表达式的值匹配
的,就执行default后面的语句。②执行完一个case后面的语句后,如果遇到break语句,则跳出switch语句;如果没有break语句,程序转到下一个case处继续执行,并不再进行判断。说明:①switch、case、default、break均是关键字。上述格式中花括号括起来的
部分称为switch语句体。switch语句体中可以没有break语句和default部分。②switch后的表达式可以是整型或字符型,不能为实型。每一个case后面的常量表达式的值必须互不相同,常量表达式中不能有变量。③default最多
只有一个,位置任意。各个case和default的出现次序不影响执行结果。④多个case可以共用一组执行语句。例3.16若有定义:floatx=1.5;inta=1,b=3,c=2;则正确的switch语句是()。A)switch
(x){case1.0:printf(“*\n”);case2.0:printf(“**\n”);}B)switch((int)x);{case1:printf(“*\n”);case2:printf(“**\n”);}C)switch(a+b){case1:prin
tf(“*\n”);case2+1:printf(“**\n”);}D)switch(a+b){case1:printf(“*\n”);casec:printf(“**\n”);}例3.17将例3.13用switch语句实现
。#include<stdio.h>main(){intgrade;printf("Pleaseinputgrade:");scanf("%d",&grade);switch(grade){case4:printf("Ex
cellent");break;case3:printf("Good");break;case2:printf("Average");break;case1:printf("Poor");break;cas
e0:printf("Failing");break;default:printf("Illegalgrade");break;}}思考:如果每个case语句之后没有break语句,程序运行的输出结果有何变化?3.5.3案例研究:个人所得税计算例3.18依法纳税是每个公民应尽的义务,我
国于1980年9月颁布施行个人所得税法,开始征收个人所得税,同时确定了个税800元的起征点。25年来,我国职工工资收入和居民消费价格指数都有较大提高,加之近年教育、住房、医疗等改革的深入,消费支出明显增长,早已超过了个人所得税法规定的每月800元
的减除费用标准。2005年10月27日第十届全国人民代表大会常务委员会第十八次会议将个人所得税起征点进行了调整,由800元调至1600元。2008年3月开始上调到此标准,目前是月收入超过2000元起征。全月应纳
税所得额(月收入-减去三险一金)与税率对照表(此表对实际用表作了简化处理)如下表所示。级数全月应纳税所得额税率(%)1不超过500元的52超过500元至2000元的部分103超过2000元至5000元的部分154超过5000元20算法1:用单分支if语句编程。算法2
:用if-else双分支结构在if子句中嵌入if语句的形式编程。算法3:用if-else-if结构,在else子句中嵌入if语句的形式编程。说明:①由于if或else子句中只允许有一条语句,因此,需要多条语句时必须用复合语句,即把需要
执行的多条语句用一对大括号括起来,否则出错。②if子句中内嵌if语句时,因为else子句总是与距离它最近的且没有配对的if相结合,而与书写的缩进格式无关,所以如果内嵌的if语句没有else分支,即不是完整的if-el
se形式时,极易发生配对错误。为了避免这类错误的发生,有两种有效方法:一是将if子句的内嵌if语句用一对大括号括起来,如上例算法2程序;二是尽量采用在else子句中内嵌if语句的形式编程,如上例中算法3程序。程序测试对程序所有的5个分支的情况分别进行测试,检验程序中的每条路径是否
都能按预定要求正确工作,这种测试方式称为白盒测试。测试中所用的数据称为测试用例。选取测试用例的原则是:尽量让测试数据覆盖程序的每条语句、每个分支和每个判断条件。