C程序设计与训练课件第04章.ppt





《C程序设计与训练课件第04章.ppt》由会员分享,可在线阅读,更多相关《C程序设计与训练课件第04章.ppt(36页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第第4章章 选择结构程序设计选择结构程序设计要设计选择结构程序,要考虑两个方面的问题:一是在C语言中如何来表示条件,二是在C语言中实现选择结构用什么语句。在C语言中表示条件,一般用关系表达式或逻辑表达式,实现选择结构用if语句或switch语句。4.1 问题的提出问题的提出4.2 关系运算和逻辑运算关系运算和逻辑运算4.3 if语句语句4.4 switch语句语句4.5 选择结构程序设计应用举例选择结构程序设计应用举例良好的源程序书写风格良好的源程序书写风格注释注释Return4.1 问题问题的提出的提出用顺序结构能编写一些简单的程序,以进行简单的运算。但是,人们对计算机运算的要求并不是仅限于
2、一些简单的运算,经常遇到要求程序进行逻辑判断,即让程序判断是否满足给定条件,并按判断结果进行不同的处理。例如:(1)从键盘输入一个数,如果它是正数,则输出,否则不输出。(2)输入一个代表年份的四位数,判断其是否是闰年。(3)输入一个考试成绩,判断它的等级(优、良、中、及格或不及格)。以上这些问题都需要程序按给定的条件进行判断,并按判断后的不同情况进行不同的处理,这类程序设计就属于选择结构,选择结构也称分支结构。Return4.2 关系运算与关系运算与逻辑运算逻辑运算4.2.1 关系运算关系运算 所谓“关系运算”实际上就是“比较运算”,即将两个数据进行比较,判定两个数据是否符合给定的关系。例如,
3、“a b”中的“”表示一个大于关系运算。如果a的值是5,b的值是3,则大于关系运算“”的结果为“真”,即条件成立;如果a的值是2,b的值是3,则大于关系运算“”的结果为“假”,即条件不成立。关系运算符及其优先次序关系运算符及其优先次序1关系运算符C语言提供6种关系运算符:(小于小于),(大于大于),=(大于或等于大于或等于),=(等于等于),!=(不等于不等于)注意注意:在语言中,“等于”关系运算符是双等号“=”,而不是单等号“=”(赋值运算符)。2优先级 (1)在关系运算符中,前4个优先级相同,后2个也相同,且前4个高于后2个。(2)与其它种类运算符的优先级关系 关系运算符的优先级,低于算术
4、运算符,但高于赋值运算符。关系表达式关系表达式 1关系表达式的概念 所谓关系表达式是指,用关系运算符将两个表达式连接起来,进行关系运算的式子。例如,下面的关系表达式都是合法的:ab,a+bc-d,(a=3)=b,(ab)=(bc)2关系表达式的值逻辑值(非“真”即“假”)。由于语言没有逻辑型数据,所以用整数“”表示“逻辑真”,用整数“”表示“逻辑假”。例如,假设num1=3,num2=4,num3=5,则:(1)num1num2的值=0。(2)(num1num2)!=num3的值=1。(3)num1num2num3的值=1。思思考考题题:任意改变num1或num2的值,会影响整个表达式的值吗?
5、为什么?(4)(num1num2)+num3的值=6,因为num1=0”。如果需要描述“x=0”、同时“x=0)&(x10),(x5),!(x=0),(year%4=0)&(year%100!=0)|(year%400=0)(2)运算规则 1)&:当且仅当两个运算量的值都为“真”时,运算结果为“真”,否则为“假”。2)|:当且仅当两个运算量的值都为“假”时,运算结果为“假”,否则为“真”。3)!:当运算量的值为“真”时,运算结果为“假”;当运算量的值为“假”时,运算结果为“真”。例如,假定x=5,则(x=0)&(x10)的值为“真”,(x5)的值为“假”。2逻辑运算符的运算优先级 (1)逻辑非
6、的优先级最高,逻辑与次之,逻辑或最低,即:!(非)&(与)|(或)(2)与其它种类运算符的优先关系 !算术运算 关系运算&|赋值运算 逻辑表达式逻辑表达式 1逻辑表达式的概念 所谓逻辑表达式是指,用逻辑运算符将1个或多个表达式连接起来,进行逻辑运算的式子。在C语言中,用逻辑表达式表示多个条件的组合。例如,(year%4=0)&(year%100!=0)|(year%400=0)就是一个判断一个年份是否是闰年的逻辑表达式。逻辑表达式的值也是一个逻辑值(非“真”即“假”)。2逻辑量的真假判定和非 语言用整数“”表示“逻辑真”、用“”表示“逻辑假”。但在判断一个数据的“真”或“假”时,却以和非为根据
7、:如果为,则判定为“逻辑假”;如果为非,则判定为“逻辑真”。例如,假设num=12,则:!num的值=,num=1 num31的值=1。3说明 (1)逻辑运算符两侧的操作数,除可以是和非的整数外,也可以是其它任何类型的数据,如实型、字符型等。(2)在计算逻辑表达式时,只有在必须执行下一个表达式才能求解时,才求解该表达式(即并不是所有的表达式都被求解)。换句话说:1)对于逻辑与运算,如果第一个操作数被判定为“假”,系统不再判定或求解第二操作数。2)对于逻辑或运算,如果第一个操作数被判定为“真”,系统不再判定或求解第二操作数。例如,假设n1、n2、n3、n4、x、y的值分别为1、2、3、4、1、1
8、,则求解表达式“(x=n1n2)&(y=n3n4)”后,x的值变为,而y的值不变,仍等于1!Return4.3 if语句语句4.3.1 if语句语句例例1 输入任意三个整数num1、num2、num3,求三个数中的最大值。/*功能:说明if 语句的格式。*/main()int num1,num2,num3,max;printf(Please input three numbers:);scanf(%d,%d,%d,&num1,&num2,&num3);if(num1num2)max=num1;else max=num2;if(num3max)max=num3;printf(The three
9、numbers are:%d,%d,%dn,num1,num2,num3);printf(max=%dn,max);程序演示程序演示程序运行情况如下:Please input three numbers:11,22,18The three numbers are:11,22,18max=22本例中的第1个if语句,可优化为如下不带else子句的形式:max=num1;if(num2max)max=num2;这种优化形式的基本思想是:首先取一个数预置为max(最大值),然后再用max依次与其余的数逐个比较,如果发现有比max大的,就用它给max重新赋值,比较完所有的数后,max中的数就是最大值。
10、这种方法,对从3个或3个以上的数中找最大值的处理,非常有效。请读者仔细体会。例例2输入任意三个数num1、num2、num3,按从小到大的顺序排序输出。main()int num1,num2,num3,temp;printf(Please input three numbers:);scanf(%d,%d,%d,&num1,&num2,&num3);if(num1num2)temp=num1;num1=num2;num2=temp;if(num2num3)temp=num2;num2=num3;num3=temp;if(num1num2)temp=num1;num1=num2;num2=tem
11、p;printf(Three numbers after sorted:%d,%d,%dn,num1,num2,num3);程序演示程序演示 程序运行情况如下:Please input three numbers:11,22,18Three numbers after sorted:11,18,22 1if语句的一般格式 if(表达式表达式)语句组语句组1;else 语句组语句组2;(1)if语句中的“表达式”必须用“(”和“)”括起来。(2)else子句(可选)是if语句的一部分,必须与if配对使用,不能单独使用。(3)当if和else下面的语句组,仅由一条语句构成时,也可不使用复合语句形式
12、(即去掉花括号)。2if语句的执行过程(1)缺省else子句时 当“表达式”的值不等于0(即判定为“逻辑真”)时,则执行语句组1,否则直接转向执行下一条。(2)指定else子句时当“表达式”的值不等于0(即判定为“逻辑真”)时,则执行语句组1,然后转向下一条语句;否则,执行语句组2。3if语句的嵌套与嵌套匹配原则 if语句允许嵌套。所谓if语句的嵌套是指,在“语句组1”或(和)“语句组2”中,又包含有if语句的情况。if语句嵌套时,else子句与if的匹匹配配原原则则:与在它上面、距它最近、且尚未匹配的if配对。为明确匹配关系,避免匹配错误,强强烈烈建建议议:将内嵌的if语句,一律用花括号括起
13、来。例例3 写一程序,从键盘上输入1年份year(4位十进制数),判断其是否闰年。闰年的条件是:能被4整除、但不能被100整除,或者能被400整除。算法设计要点算法设计要点:(1)如果能被整除,则余数为,即如果的值等于,则表示能被整除!(2)首先将是否闰年的标志leap预置为0(非闰年),这样仅当year为闰年时将leap置为1即可。这种处理两种状态值的方法,对优化算法和提高程序可读性非常有效,请读者仔细体会。参考程序如下:/*功能:说明if语句的嵌套格式和用法。*/main()int year,leap=0;/*leap=0:预置为非闰年*/printf(Please input the y
14、ear:);scanf(%d,&year);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);程序演示程序演示利用逻辑运算能描述复杂条件的特点,可将上述程序优化如下:main()int year;printf(Please input the year:);scanf(%d,&year);if(year%4=0&year%100!=0)|(year%400=0)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 训练 课件 04

限制150内