版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第5章 挑选结构程序设计要设计挑选结构程序要设计挑选结构程序,要思考两个角度的咨询要思考两个角度的咨询题题:一是在一是在C语言中似何来示意前提语言中似何来示意前提,二是在二是在C语言语言中实现挑选结构用啥语句中实现挑选结构用啥语句.在在C语言中示意前提语言中示意前提,一样用关系表达式或逻一样用关系表达式或逻辑表达式辑表达式,实现挑选结构用实现挑选结构用if语句或语句或switch语句语句.5.1 关系运算及其表达式关系运算及其表达式5.2 逻辑运算及其表达式逻辑运算及其表达式5.3 if语句语句5.4 switch语句语句5.5 挑选结构程序举例挑选结构程序举例良好的源程序书写风格良好的源程序
2、书写风格注释注释第五章第五章 挑选结构程序设计挑选结构程序设计依照挑选结构的组成特点依照挑选结构的组成特点, ,对比咨询题时着重对比咨询题时着重明白以下两点明白以下两点: :1 1)前提是啥)前提是啥2 2)前提成站和不成站时分不履行啥操纵)前提成站和不成站时分不履行啥操纵. . 引例引例统计函数值统计函数值: sin(x)x x0y= 1 x=0需思考需思考: :输入输入x x推断推断x x的值的值依照依照x x值值, ,统计统计y y值值输出输出y y值值明显明显,次序程序不能够实现次序程序不能够实现,须引须引入挑选结构程序入挑选结构程序.关系运算关系运算挑选结构挑选结构Enter x:
3、2x=2.00 y=0.45465.1 关系运算及其表达式 所谓所谓“关系运算关系运算”现实上便是现实上便是“对比运算对比运算”,立即两立即两个信息履行对比个信息履行对比,推断两个信息是否吻合给定的关系推断两个信息是否吻合给定的关系. 例似例似,“a b”中的中的“”示意一个大于关系运算示意一个大于关系运算.似果似果a的值是的值是5,b的值是的值是3,那么大于关系运算那么大于关系运算“”的结论为的结论为“真真”,即前提成站;似果即前提成站;似果a的值是的值是2,b的值是的值是3,那么大于关那么大于关系运算系运算“”的结论为的结论为“假假”,即前提不成站即前提不成站.5.1.1 关系运算符及其优
4、先次序1关系运算符C语言提供6种关系运算符: (小于) (大于) = (大于或等于) = (等于) != (不等于)注重:在语言中,“等于”关系运算符是双等号 “= =”,而不是单等号“= ”(赋值运算符). 2优先级 (1)在关系运算符中,前4个优先级一样,后2个也一样,且前4个高于后2个. (2)与其它种类运算符的优先级关系 关系运算符的优先级,低于算术运算符,但高于赋值运算符.(P366) 5.1.2 关系表达式 1关系表达式的概念: 用关系运算符将两个表达式毗邻起来,履行关系运算的式子. 例似,下面的关系表达式根基上合法的: ab, a+bc-d, (a=3)=b, (ab)= =(b
5、c)2关系表达式的值逻辑值(非“真”即“假”). 因为语言没有逻辑型信息,所以用:整数“”示意“逻辑真”;用整数“”示意“逻辑假”.例似例似,假定假定n1=3,n2=4,n3=5,那么那么: (1)n1n2的值的值 (2)(n1n2)!=n3的值的值 (3)n1n3n2的值的值 (4)(n1=0”.似果需要描述似果需要描述“x=0”、同时、同时“x=0) & (x10) ,(x5) ,! (x= =0), (year%4=0)&(year%100!=0)|(year%400=0) (2)运算法那么)运算法那么 1)&:当且仅当两个运算量的值都为当且仅当两个运算量的值都为
6、“真真”时时,运算结论为运算结论为“真真”,否那么为否那么为“假假”. 2) | :当且仅当两个运算量的值都为当且仅当两个运算量的值都为“假假”时时,运运算结论为算结论为“假假”,否那么为否那么为“真真”. 3) ! :当运算量的值为当运算量的值为“真真”时时,运算结论为运算结论为“假假”;当运算量的值为;当运算量的值为“假假”时时,运算结论为运算结论为“真真”.例似例似,假定假定x=5,那么那么(x=0) & (x10)的值为的值为“真真”, (x5)的值为的值为“假假”. 2逻辑运算符的运算优先级逻辑运算符的运算优先级(P93) (1) 逻辑非的优先级最高逻辑非的优先级最高,逻辑与
7、次之逻辑与次之,逻辑或逻辑或最低最低,即即:!(非)!(非) &(与)(与) |(或)(或)(2) 与其它种类运算符的优先关系与其它种类运算符的优先关系 ! 算术运算算术运算 关系运算关系运算 & | 赋赋值运算值运算 5.2.2 逻辑表达式 1逻辑表达式:是指用逻辑运算符将1个或多个表达式毗邻起来,履行逻辑运算的式子.在C语言中,用逻辑表达式示意多个前提的组合. 例似,(year%4=0)&(year%100!=0)|(year%400=0)是一个推断一个年份是否是闰年的逻辑表达式. 逻辑表达式的值也是一个逻辑值(非“真”即“假”). 2逻辑量的真假推断逻辑量的真假推
8、断和非和非 语言用整数语言用整数“”示意示意“逻辑真逻辑真”、用、用“”示意示意“逻辑假逻辑假”. 推断一个信息的推断一个信息的“真真”或或“假假”时时,却以和非却以和非为依照为依照:似果为似果为,那么推断为那么推断为“逻辑假逻辑假”;似果为非;似果为非,那么推断为那么推断为“逻辑真逻辑真”. 例似例似,假定假定num=12,那么那么: !num的值的值 num=1 num31的值的值 011 3 3讲明讲明(1 1)逻辑运算符两侧的操纵数)逻辑运算符两侧的操纵数, ,除能够是除能够是和非的整数外和非的整数外, ,也能够是其它任何类型的信也能够是其它任何类型的信息息, ,似实型、字符型等似实型
9、、字符型等. .(2 2)在统计逻辑表达式时)在统计逻辑表达式时, ,只有在必须履行只有在必须履行下一个表达式才能求解时下一个表达式才能求解时, ,才求解该表达式才求解该表达式(即同时不是全部的表达式都被求解)(即同时不是全部的表达式都被求解). .即即: : 1 1)对逻辑与运算)对逻辑与运算, ,似果第一个操纵数似果第一个操纵数被推断为被推断为“假假”, ,系统不再推断或求解第二操系统不再推断或求解第二操纵数纵数. . 2 2)对逻辑或运算)对逻辑或运算, ,似果第一个操纵数似果第一个操纵数被推断为被推断为“真真”, ,系统不再推断或求解第二操系统不再推断或求解第二操纵数纵数. . 例似例
10、似,假定假定n1=1、n2=2、n3=3、n4=4、x=1、y=1那么求解表达式那么求解表达式“(x=n1n2)&(y=n3n4)”后后,x=?,y=?,表达式的值表达式的值=?0105.3 if5.3 if语句和前提运算符语句和前提运算符5.3.1 if语句例5.1 输入随意率性三个整数n1、n2、n3,求三个数中的最大值.*例代码文件名:L5_1.C.功能:讲明if 语句的标准.*#include main()int n1,n2,n3,max; printf(“Please input three numbers:”); scanf(“%d,%d,%d”,&n1,&
11、n2,&n3); if (n1n2) max=n1; else max=n2; if (n3max) max=n3; printf(“The three numbers are: %d,%d,%dn,n1,n2,n3); printf(max=%dn,max);程序运行情况似下程序运行情况似下:Please input three numbers:11,22,18 The three numbers are:11,22,18max=22这种优化形式的根基理念是这种优化形式的根基理念是:第一步取一个数预置为第一步取一个数预置为max(最(最大值)大值),接着再用接着再用max依次与其余依
12、次与其余的数追个对比的数追个对比,似果发觉有比似果发觉有比max大的大的,便用它给便用它给max再一次赋值再一次赋值,对比完全部的数后对比完全部的数后,max中的数便中的数便是最大值是最大值.这种方式这种方式,对从对从3个或个或3个以上的数中寻最大值的操作个以上的数中寻最大值的操作,非常有效非常有效.max=n1;if(n2max) max=n2;例例5.2输入随意率性三个数输入随意率性三个数n1、n2、n3,按从小到大的次序排序输出按从小到大的次序排序输出.*例代码文件名例代码文件名:L5_2.C.*(P98)#include main()int n1,n2,n3,temp; printf(
13、Please input three numbers:); scanf(%d,%d,%d,&n1,&n2,&n3); if (n1n2) temp=n1;n1=n2;n2=temp; if (n2n3) temp=n2;n2=n3;n3=temp; if (n1n2) temp=n1;n1=n2;n2=temp; printf(Three numbers after sorted: %d,%d,%dn,n1,n2,n3);程序运行情况似下程序运行情况似下:Please input three numbers: 22,18,11 Three numbers after s
14、orted: 11,18,221if语句的一样标准语句的一样标准 if(表达式表达式) 语句组语句组1; else 语句组语句组2; (1)if语句中的语句中的“表达式表达式”必须用必须用“(”和和“)”括起括起来来. (2)else子句(可选)是子句(可选)是if语句的一部分语句的一部分,必须与必须与if配对使用配对使用,不能单独使用不能单独使用. (3)当)当if和和else下面的语句组下面的语句组,仅由一条语句构成时仅由一条语句构成时,也可不使用复合语句形式也可不使用复合语句形式,即去掉花括号即去掉花括号“ ”.2if语句的履行环节语句的履行环节(1)缺省)缺省else子句时子句时(P9
15、6) 当当“表达式表达式”的值不等于的值不等于0(即推断为(即推断为“逻辑真逻辑真”)时时,那么履行语句组那么履行语句组1,否那么直截了当转向履行下一条否那么直截了当转向履行下一条.似图似图5-5(a)所示所示.(2)指定)指定else子句时子句时 当当“表达式表达式”的值不等于的值不等于0(即推断为(即推断为“逻辑真逻辑真”)时时,那么履行语句组那么履行语句组1,接着转向下一条语句;否那么接着转向下一条语句;否那么,履履行语句组行语句组2.似图似图5-5(b)所示所示. 3if语句的嵌套与嵌套匹配原那么语句的嵌套与嵌套匹配原那么 if语句许可嵌套语句许可嵌套.所谓所谓if语句的嵌套是指语句的
16、嵌套是指,在在“语句组语句组1”或(和)或(和)“语句组语句组2”中中,又见谅有又见谅有if语句的情况语句的情况. if语句嵌套时语句嵌套时,else子句与子句与if的匹配原那么的匹配原那么:与在它上与在它上面、距它近来、且尚未匹配的面、距它近来、且尚未匹配的if配对配对. 为明白匹配关系为明白匹配关系,幸免匹配错误幸免匹配错误,定见定见:将内嵌的将内嵌的if语语句句,一律用花括号括起来一律用花括号括起来.表达式表达式语句语句1真(非真(非0)假假(0) 前提前提 语句语句1 语句语句2YN例例5.3 写一程序写一程序,从键盘上输入一个年份从键盘上输入一个年份year(4位十位十进制数)进制数
17、),推断其是否闰年推断其是否闰年.算法设计要点算法设计要点: 1)闰年的前提是)闰年的前提是:能被能被4整除、但不能被整除、但不能被100整除整除,大大概能被概能被400整除整除. 2)似果能被整除)似果能被整除,那么余数为那么余数为,即似果的即似果的值等于值等于,那么示意能被整除!那么示意能被整除! 3)第一步将是否闰年的标记)第一步将是否闰年的标记leap预置为预置为0(非闰年)(非闰年),如此仅当如此仅当year为闰年时将为闰年时将leap置为置为1即可即可.这种操作两种这种操作两种状态值的方式状态值的方式,对优化算法和提高程序可读性非常有效对优化算法和提高程序可读性非常有效.#incl
18、ude main()int year,leap=0; * leap=0:预置为非闰年预置为非闰年* printf(Please input the year:); scanf(%d,&year); if (year % 4=0) if (year % 100 != 0) leap=1; if (year%400=0) leap=1; if (leap) printf(%d is a leap year.n,year); else printf(%d is not a leap year.n,year);操纵逻辑运算能描述复杂前提的特点操纵逻辑运算能描述复杂前提的特点,可将上述程序优化似
19、下可将上述程序优化似下:#include main()int year; printf(Please input the year:); scanf(%d,&year); if (year%4=0 & year%100!=0)|(year%400=0) printf(%d is a leap year.n,year); else printf(%d is not a leap year.n,year);参考程序似下参考程序似下:*例代码文件名例代码文件名:L5_3.C.*功能功能:讲明讲明if语句的嵌套标准和用法语句的嵌套标准和用法.*4讲明 (1)if背面的“表达式”,除常见
20、的关系表达式或逻辑表达式外,也许可是其它类型的信息,似整型、实型、字符型等. (2)if语句许可嵌套,但嵌套的层数不宜太多.在现实编程时,应恰当操纵嵌套层数(23层). (3)“语句组1”和“语句组2”,能够只见谅一个简单语句,也能够是复合语句.务必紧记:不管是简单语句,仍是复合语句中的各个语句,每个语句背面的分号必不可少! 例似,例5.1中的: if (n1n2) max=n1; else max=n2; if行背面的赋值语句“max=n1;”分号不能省略.但不要误信任if和else是2个独站的语句,它们都属于if语句中的一部分,else是if语句的子句.5.3.2 前提运算符 1一样标准:
21、 表达式1?表达式2:表达式3 前提表达式中的“表达式1”、“表达式2”、“表达式3”的类型,能够各不一样. 2运算法那么 似果“表达式1”的值为非0(即逻辑真), 那么运算结论等于“表达式2”的值;否那么,运算结论等于“表达式3”的值.似图5-11所示. 3运算符的优先级与联合性 前提运算符的优先级,高于赋值运算符,但低于关系运算符和算术运算符.其联合性为“从右到左”(即右联合性).#include main() char ch; printf(Input a character: ); scanf(%c,&ch); ch=(ch=A & ch=Z) ? (ch+32) :
22、ch ; printf(ch=%cn,ch); 例5.4 从键盘上输入一个字符,似果它是大写字母,那么把它变形成小写字母输出;否那么,直截了当输出.*例文件名:L5_4.C*5.4 switch语句语句C语言提供了语言提供了switch语句直截了当操作多分支挑选语句直截了当操作多分支挑选.例例5.5 从键盘上输入一个百分制成绩从键盘上输入一个百分制成绩score,按下列原那么输出其等按下列原那么输出其等级级:score90,等级为等级为A;80score90,等级为等级为B;70score80,等级为等级为C;60score70,等级为等级为D;score60,等级为等级为E.*例代码文件名例
23、代码文件名:AL5_5.C.* #include main()int score, grade; printf(“Input a score(0100): ”); scanf(“%d”, &score); grade = score10; *将成绩整除将成绩整除10,转化成转化成switch语句中的语句中的case标号标号* switch (grade) case 10: case 9: printf(“grade=An”); break; case 8: printf(grade=Bn); break; case 7: printf(grade=Cn); break; case 6:
24、 printf(grade=Dn); break; case 5: case 4: case 3: case 2: case 1: case 0: printf(“grade=En”); break; default: printf(“The score is out of range!n”);程序运行情况似下程序运行情况似下:Input a score(0100): 85 grade=B1switch语句的一样形式语句的一样形式switch(表达式表达式) case 常量表达式常量表达式1:语句组;语句组;break; case 常量表达式常量表达式2:语句组;语句组;break; . ca
25、se 常量表达式常量表达式:语句组;语句组;break; default:语句组;语句组;break; 2履行环节履行环节 1)当)当switch背面背面“表达式表达式”的值的值,与某个与某个case背背面的面的“常量表达式常量表达式”的值一样时的值一样时,便履行该便履行该case背面背面的语句(组);当履行到的语句(组);当履行到break语句时语句时,跳出跳出switch语句语句,转向履行转向履行switch语句的下一条语句的下一条. 2)似果没有任何一个)似果没有任何一个case背面的背面的“常量表达式常量表达式”的值的值,与与“表达式表达式”的值匹配的值匹配,那么履行那么履行defau
26、lt 背面背面的语句(组)的语句(组).接着接着,再履行再履行switch语句的下一条语句的下一条.3讲明讲明 (1)switch背面的背面的“表达式表达式”,能够是能够是int、char和枚举型中的一种和枚举型中的一种. (2)每个)每个case背面背面“常量表达式常量表达式”的值的值,必须必须各不一样各不一样,否那么会表现彼此抵牾的现象(即对否那么会表现彼此抵牾的现象(即对表达式的同一值表达式的同一值,有两种或两种以上的履行方有两种或两种以上的履行方案)案). (3)case背面的常量表达式仅起语句标号作背面的常量表达式仅起语句标号作用用,同时不履行前提推断同时不履行前提推断.系同一旦寻到
27、入口标号系同一旦寻到入口标号,便从此标号最先履行便从此标号最先履行,不再履行标号推断不再履行标号推断,所以必所以必须加上须加上break语句语句,以便结束以便结束switch语句语句.摸索题摸索题:似果去掉似果去掉例例5.5程序中的全部程序中的全部break语句语句,且输入的成绩为且输入的成绩为75,输出会似何?输出会似何?(4)各)各case及及default子句的先后次序子句的先后次序,不作用程序履行结论不作用程序履行结论.(5)多个)多个case子句子句,可共用同一语句(组)可共用同一语句(组).例似例似,在在例例5.5中中,case 10: 和和case 9: 共用语句【共用语句【pr
28、intf(”grade=An“); break;】case 5: case 0: 共用语句【共用语句【printf(”grade=En“); break;】(6)用)用switch语句实现的多分支结构程序语句实现的多分支结构程序,完全能够用完全能够用if语句或语句或if语句的嵌套来实现语句的嵌套来实现.5.5 挑选结构程序设计举例挑选结构程序设计举例#include #include main() float a,b,c,disc,x1,x2,p,q; scanf(“%f,%f,%f”, &a, &b, &c); disc=b*b-4*a*c; if (fabs(dis
29、c)1e-6) x1=(-b+sqrt(disc)(2*a);*求出两个不相等的实根求出两个不相等的实根* x2=(-b-sqrt(disc)(2*a); printf(x1=%7.2f,x2=%7.2fn, x1, x2); else p=-b(2*a);*求出两个共轭复根求出两个共轭复根* q=sqrt(fabs(disc)(2*a); printf(“x1=%7.2f + %7.2f in“, p, q);*输出两个共轭复根输出两个共轭复根* printf(”x2=%7.2f - %7.2f in“, p, q); 例例5.6 求一元二次方程求一元二次方程ax2+bx+c=0的解(的解(
30、a0).(P108)*例代码文件名例代码文件名:L5_6.C.*讲明讲明:因为实数在统计机中存储时因为实数在统计机中存储时,常常常会有部分藐小误差常会有部分藐小误差,所以本例推断所以本例推断disc是否为是否为0的方式是的方式是:推断推断disc的绝的绝对值是否小于一个非常小的数(例似对值是否小于一个非常小的数(例似10-6).例例5.7 已知某公司职员的保底薪水为已知某公司职员的保底薪水为500,某月所接工程的利润某月所接工程的利润profit(整数)与(整数)与利润提成的关系似下(计量单位利润提成的关系似下(计量单位:元)元)(P110) profit1000没有提成;没有提成;1000
31、profit2000提成提成10%;2000 profit5000提成提成15%;5000 profit10000提成提成20%;10000profit提成提成25%. 算法设计要点算法设计要点:为使用为使用switch语句语句,必须将利润必须将利润profit与提成的关系与提成的关系,变形成某些整数与提成的关系变形成某些整数与提成的关系.对比本题可知对比本题可知,提成的改变点根基上提成的改变点根基上1000的整数倍(的整数倍(1000、2000、5000、),似果将利润似果将利润profit整除整除1000,那么当那么当: profit1000对应对应0、11000 profit2000对应
32、对应1、22000 profit5000对应对应2、3、4、55000 profit10000对应对应5、6、7、8、9、1010000profit对应对应10、11、12、 为解决相邻两个区间的叠加咨询题为解决相邻两个区间的叠加咨询题,最简单的方式便是最简单的方式便是:利润利润profit先减先减1(最小增(最小增量)量),接着再整除接着再整除1000即可即可: profit1000对应对应0 1000 profit2000对应对应1 2000 profit5000对应对应2、3、4 5000 profit10000对应对应5、6、7、8、9 10000profit对应对应10、11、12、
33、*例代码文件名例代码文件名:AL5_7.C.*#include main() long profit; int grade; float salary=500; printf(Input profit: ); scanf(%ld, &profit); grade= (profit 1) 1000;*将利润将利润-1、再整除、再整除1000,转化成转化成 switch语句中的语句中的case标号标号* switch (grade) case 0: break;*profit1000 * case 1: salary += profit*0.1; break;*1000profit2000 * case 2: case 3: case 4: salary += profit*0.15; break; *2000profit5000 * case 5: case 6: case 7: case 8: case 9
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 河北省衡水市武强中学2024-2025学年高一上学期期中考试数学试题(含答案)
- 2024年度云南省高校教师资格证之高等教育学自我检测试卷A卷附答案
- 数据中心建设方案
- 赣南师范大学《三维动画制作》2022-2023学年第一学期期末试卷
- 阜阳师范大学《通信工程专业导论》2021-2022学年第一学期期末试卷
- 人教版小学四年级体育教案上册
- 福建师范大学《通信一》2021-2022学年第一学期期末试卷
- 福建师范大学《民事诉讼法》2023-2024学年第一学期期末试卷
- 档案利用效果登记表
- 2024年嘉峪关客运从业资格证考试模拟试题
- 2024成都中考数学二轮重点专题研究 实数的相关概念(课件)
- 道路开口施工方案6
- 国开作业《公共关系学》实训项目1:公关三要素分析(六选一)参考552
- 大学劳动教育(高等院校劳动教育课程)全套教学课件
- 人教版七级下《第五章相交线与平行线》单元测试题含试卷分析答题技巧
- 二年级上册语文第四单元《日月潭》教学课件 第1课时
- MOOC 英语语法与写作-暨南大学 中国大学慕课答案
- 妇科腹腔镜手术术前宣教
- 2017年天津滨海新区公务员考试《行测》真题
- 2023-2024学年北京市延庆区八年级上学期期中考试数学试卷含详解
- 2024年中考数学专项复习模型33旋转-奔驰模型-原卷版+解析
评论
0/150
提交评论