




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第第4章章 选择结构程序设计选择结构程序设计 要设计选择结构程序,要考虑两个方面的问题:一是 在C语言中如何来表示条件,二是在C语言中实现选择结 构用什么语句。 在C语言中表示条件,一般用关系表达式或逻辑表达 式,实现选择结构用if语句或switch语句。 4.1 关系运算及其表达式关系运算及其表达式 4.2 逻辑运算及其表达式逻辑运算及其表达式 4.3 if语句语句 4.4 switch语句语句 4.5 选择结构程序举例选择结构程序举例 良好的源程序书写风格良好的源程序书写风格注释注释 Return 4.1 关系运算及其表达式关系运算及其表达式 所谓“关系运算”实际上就是“比较运算”,即将
2、两个数据进行比较,判定两个数据是否符合给定的关系。 例如,“a b”中的“”表示一个大于关系运算。如 果a的值是5,b的值是3,则大于关系运算“”的结果为 “真”,即条件成立;如果a的值是2,b的值是3,则大 于关系运算“”的结果为“假”,即条件不成立。 4.1.1 关系运算符及其优先次序关系运算符及其优先次序 1关系运算符 C语言提供6种关系运算符: (小于小于), (大于大于), =(大于或等于大于或等于), =(等于等于), !=(不等于不等于) 注意注意:在语言中,“等于”关系运算符是双等号 “= =”,而不是单等号“= ”(赋值运算符)。 2优先级 (1)在关系运算符中,前4个优先级
3、相同,后2个也相同,且前4 个高于后2个。 (2)与其它种类运算符的优先级关系 关系运算符的优先级,低于算术运算符,但高于赋值运算符。 4.1.2 关系表达式关系表达式 1关系表达式的概念 所谓关系表达式是指,用关系运算符将两个表达式连 接起来,进行关系运算的式子。 例如,下面的关系表达式都是合法的: ab,a+bc-d,(a=3)=b,(ab)= =(bc) 2关系表达式的值逻辑值(非“真”即“假”)。 由于语言没有逻辑型数据,所以用整数“”表示 “逻辑真”,用整数“”表示“逻辑假”。 例如,假设num1=3,num2=4,num3=5,则: (1)num1num2的值=0。 (2)(num
4、1num2)!=num3的值=1。 (3)num1num2num3的值=1。 思考题思考题:任意改变num1或num2的值,会影响整个表 达式的值吗?为什么? (4)(num1num2)+num3的值=6,因为num1=0”。如果 需要描述“x=0”、同时“x=0) printf(Please input three numbers:); scanf(%d,%d,%d, if (num1num2) max=num1; else max=num2; if (num3max) max=num3; printf(The three numbers are:%d,%d,%dn,num1,num2,nu
5、m3); printf(max=%dn,max); 程序演示程序演示 程序运行情况如下: Please input three numbers:11,22,18 The three numbers are:11,22,18 max=22 本案例中的第1个if语句,可优化为如下不带else子句 的形式: max=num1; if(num2max) max=num2; 这种优化形式的基本思想是:首先取一个数预置为 max(最大值),然后再用max依次与其余的数逐个比较, 如果发现有比max大的,就用它给max重新赋值,比较完 所有的数后,max中的数就是最大值。这种方法,对从3 个或3个以上的数中
6、找最大值的处理,非常有效。请读者 仔细体会。 案例案例4.2输入任意三个数num1、num2、num3,按从小到大的顺序 排序输出。 /*案例代码文件名:AL4_2.C。*/ main() int num1,num2,num3,temp; printf(Please input three numbers:); scanf(%d,%d,%d, if (num1num2) temp=num1;num1=num2;num2=temp; if (num2num3) temp=num2;num2=num3;num3=temp; if (num1num2) temp=num1;num1=num2;num
7、2=temp; printf(Three numbers after sorted: %d,%d,%dn,num1,num2,num3); 程序演示程序演示 程序运行情况如下: Please input three numbers:11,22,18 Three numbers after sorted: 11,18,22 1if语句的一般格式 if(表达式表达式) 语句组语句组1; else 语句组语句组2; (1)if语句中的“表达式”必须用“(”和“)”括起来。 (2)else子句(可选)是if语句的一部分,必须与if配对使用,不 能单独使用。 (3)当if和else下面的语句组,仅由一条
8、语句构成时,也可不使 用复合语句形式(即去掉花括号)。 2if语句的执行过程 (1)缺省else子句时 当“表达式”的值不等于0(即判定为“逻辑真”) 时,则执行语句组1,否则直接转向执行下一条。如图4- 1(a)所示。 (2)指定else子句时 当“表达式”的值不等于0(即判定为“逻辑真”) 时,则执行语句组1,然后转向下一条语句;否则,执行 语句组2。如图4-1(b)所示。 3if语句的嵌套与嵌套匹配原则 if语句允许嵌套。所谓if语句的嵌套是指,在“语句 组1”或(和)“语句组2”中,又包含有if语句的情况。 if语句嵌套时,else子句与if的匹配原则匹配原则:与在它上 面、距它最近、
9、且尚未匹配的if配对。 为明确匹配关系,避免匹配错误,强烈建议强烈建议:将内 嵌的if语句,一律用花括号括起来。 案例案例4.3 写一程序,从键盘上输入1年份year(4位十 进制数),判断其是否闰年。闰年的条件是:能被4整除、 但不能被100整除,或者能被400整除。 算法设计要点算法设计要点: (1)如果能被整除,则余数为,即如果 的值等于,则表示能被整除! (2)首先将是否闰年的标志leap预置为0(非闰年), 这样仅当year为闰年时将leap置为1即可。这种处理两种状 态值的方法,对优化算法和提高程序可读性非常有效, 请读者仔细体会。参考程序如下: /*案例代码文件名:AL4_3.C
10、。*/ /*功能:说明if语句的嵌套格式和用法。*/ main() int year,leap=0;/* leap=0:预置为非闰年*/ printf(Please input the year:); scanf(%d, if (year % 4=0) if (year % 100 != 0) leap=1; else 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); 程序演示程序演示 利用逻辑运算能描述复杂条件的特点,可将
11、上述程序优化如下: main() int year; printf(Please input the year:); scanf(%d, if (year%4=0 else printf(%d is not a leap year.n,year); 4说明 (1)if后面的“表达式”,除常见的关系表达式或逻辑表达式外, 也允许是其它类型的数据,如整型、实型、字符型等。 (2)if语句允许嵌套,但嵌套的层数不宜太多。在实际编程时, 应适当控制嵌套层数(23层)。 (3)“语句组1”和“语句组2”,可以只包含一个简单语句,也可 以是复合语句。 务必牢记务必牢记:不管是简单语句,还是复合语句中的各个
12、语句,每个 语句后面的分号必不可少! 例如,案例案例4.1中的: if (num1num2) max=num1; else max=num2;语句: if行后面的赋值语句“max=num1;”分号不能省略。但不要误认为if 和else是2个独立的语句,它们都属于if语句中的一部分,else是if语句 的子句。 4.3.2 条件运算符条件运算符 1一般格式: 表达式1?表达式2:表达式3 条件表达式中的“表达式1”、“表达式2”、“表达 式3”的类型,可以各不相同。 2运算规则 如果“表达式1”的值为非0(即逻辑真), 则运算结果 等于“表达式2”的值;否则,运算结果等于“表达式3”的 值。如图
13、4-2所示。 3运算符的优先级与结合性 条件运算符的优先级,高于赋值运算符,但低于关 系运算符和算术运算符。其结合性为“从右到左”(即 右结合性)。 例例4.4 从键盘上输入一个字符,如果它是大写字母, 则把它转换成小写字母输出;否则,直接输出。 /*案例文件名:AL4_4.C*/ main() char ch; printf(Input a character: ); scanf(%c, ch=(ch=A printf(ch=%cn,ch); 程序演示程序演示 Return 4.4 switch语句语句 C语言提供了switch语句直接处理多分支选择。 案例案例4.5 从键盘上输入一个百分制
14、成绩score,按下列原则输出其 等级:score90,等级为A;80score90,等级为B;70score80, 等级为C;60score70,等级为D;score60,等级为E。 /*案例代码文件名:AL4_5.C。*/ main() int score, grade; printf(“Input a score(0100): ”); scanf(“%d”, grade = score/10; /*将成绩整除10,转化成switch语句中的case标号*/ switch (grade) case 10: case 9: printf(“grade=An”); break; case 8:
15、 printf(grade=Bn); break; case 7: printf(grade=Cn); break; case 6: 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=B 1switch语句的一般形式 switch(表达式) case 常量
16、表达式1:语句组;break; case 常量表达式2:语句组;break; . case 常量表达式:语句组;break; default:语句组;break; 2执行过程 (1)当switch后面“表达式”的值,与某个case后面 的“常量表达式”的值相同时,就执行该case后面的语句 (组);当执行到break语句时,跳出switch语句,转向执 行switch语句的下一条。 (2)如果没有任何一个case后面的“常量表达式” 的值,与“表达式”的值匹配,则执行default 后面的语 句(组)。然后,再执行switch语句的下一条。 3说明 (1)switch后面的“表达式”,可以是i
17、nt、char和枚 举型中的一种。 (2)每个case后面“常量表达式”的值,必须各不 相同,否则会出现相互矛盾的现象(即对表达式的同一 值,有两种或两种以上的执行方案)。 (3)case后面的常量表达式仅起语句标号作用,并后面的常量表达式仅起语句标号作用,并 不进行条件判断不进行条件判断。系统一旦找到入口标号,就从此标号 开始执行,不再进行标号判断,所以必须加上break语句, 以便结束switch语句。 思考题思考题:如果去掉案例案例4.5程序中的所有break语句, 且输入的成绩为75,输出会如何? (4)各case及default子句的先后次序,不影响程序执 行结果。 (5)多个cas
18、e子句,可共用同一语句(组)。 例如,在案例案例4.5中的“case 10: ”和“case 9: ”共用 语句“printf(grade=An); break;”,“case 5: ”“case 0: ” 共用语句“printf(grade=En); break;”。 (6)用switch语句实现的多分支结构程序,完全可 以用if语句或if语句的嵌套来实现。 Return 4.5 选择结构程序设计举例选择结构程序设计举例 案例案例4.6 求一元二次方程ax2+bx+c=0的解(a0)。 /*案例代码文件名:AL4_6.C。*/ /*功能:求一元二次方程的解。*/ #include math.
19、h main() float a,b,c,disc,x1,x2,p,q; scanf(“%f,%f,%f”, disc=b*b-4*a*c; if (fabs(disc)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
20、(”x2=%7.2f - %7.2f in“, p, q); 程序演示程序演示 说明说明:由于实数在计算机中存储时,经常会有一些 微小误差,所以本案例判断disc是否为0的方法是:判断 disc的绝对值是否小于一个很小的数(例如10-6)。 思考题思考题:如果将系数a、b、c定义成整数,能否直接 判断disc是否等于0? 案例案例4.7 已知某公司员工的保底薪水为500,某月所接工程的利 润profit(整数)与利润提成的关系如下(计量单位:元): profit1000没有提成; 1000profit2000提成10%; 2000profit5000提成15%; 5000profit10000
21、提成20%; 10000profit提成25%。 算法设计要点:算法设计要点: 为使用switch语句,必须将利润profit与提成的关系,转换成某些 整数与提成的关系。分析本题可知,提成的变化点都是1000的整数倍 (1000、2000、5000、),如果将利润profit整除1000,则当: profit1000对应0、1 1000profit2000对应1、2 2000profit5000对应2、3、4、5 5000profit10000对应5、6、7、8、9、10 10000profit对应10、11、12、 为解决相邻两个区间的重叠问题,最简单的方法就是:利润 profit先减1(最
22、小增量),然后再整除1000即可: profit1000对应0 1000profit2000对应1 2000profit5000对应2、3、4 5000profit10000对应5、6、7、8、9 10000profit对应10、11、12、 /*案例代码文件名:AL4_7.C。*/ main() long profit; int grade; float salary=500; printf(Input profit: ); scanf(%ld, 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
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 娱乐公司艺人培养与版权保护策略研究
- 2025年南京货运从业资格证模拟考试试题答案
- 新闻传播学理论与实践案例研究
- 餐饮业知识竞赛试题
- 新疆维吾尔自治区伊犁哈萨克自治州“华-伊高中联盟校”2022-2023学年高一下学期期中联考地理试题(含答案)
- 江苏省盐城市东台市第二教育联盟2023-2024学年八年级下学期物理期中试题(含答案)
- 2024年4月二次结构施工合同材料批次追溯管理系统
- 出借人合同样本
- 入驻创意合同标准文本
- 中标合同和施工合同样本
- 2025年北京市东城区高三一模数学试卷(含答案)
- 2025-2030中国电子焊膏行业市场发展趋势与前景展望战略研究报告
- 护士的礼仪培训
- 炎德·英才大联考湖南师大附中2025届高三月考试卷(七)物理试卷(含答案)
- 内镜检查操作流程
- 2025年湖北省八市高三(3月)联考化学
- 2025年新音乐节明星艺人歌手演出场费报价单
- 2025年吉林司法警官职业学院单招职业技能考试题库汇编
- 2025安徽省亳州城建发展控股集团限公司招聘81人历年自考难、易点模拟试卷(共500题附带答案详解)
- 德育测试试题及答案
- 母婴护理师、月嫂考试、产妇护理重点知识考试题(附答案)
评论
0/150
提交评论