《【教学课件】第3章分支程序设计.ppt》由会员分享,可在线阅读,更多相关《【教学课件】第3章分支程序设计.ppt(30页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、程序设计 cs.sjtu 2011.9程序设计-1第第3章章 分支程序设计分支程序设计关系表达式关系表达式逻辑表达式逻辑表达式If 语句语句Switch语句语句程序设计 cs.sjtu 2011.9程序设计-2关关系表达式系表达式v关系表达式用来实现比较关系表达式用来实现比较v关系运算符关系运算符 ,=,=,=,=,=,=,!=优先级:高于赋值运算符,低于算术运算符。优先级:高于赋值运算符,低于算术运算符。关系运算符内部:关系运算符内部:=和和 !=较低较低 结合性:左结合结合性:左结合v关系表达式关系表达式 用关系运算符将二个表达式连接起来称为关系表达式用关系运算符将二个表达式连接起来称为关
2、系表达式 关系表达式的结果是:关系表达式的结果是:true true 或或 falsefalseeg.x y a b=c d a b=c d 都是合法的关系表达式都是合法的关系表达式注意:注意:-2 -1 0 -2 -1 6-2(5+3)(6 2)程序设计 cs.sjtu 2011.9程序设计-4第第3章章 逻辑思维及分支程序设计逻辑思维及分支程序设计关系表达式关系表达式逻辑表达式逻辑表达式If语句语句Switch语句语句程序设计 cs.sjtu 2011.9程序设计-5逻辑表达式逻辑表达式v逻辑表达是用于实现更复杂的判断逻辑表达是用于实现更复杂的判断v逻辑运算符逻辑运算符&(and)|(or
3、)!(not)优先级:优先级:!关系运算符关系运算符&|v逻辑表达式逻辑表达式 由逻辑运算符连接起来的表达式由逻辑运算符连接起来的表达式,其结果为其结果为“真真(true)”或或“假假(false)”程序设计 cs.sjtu 2011.9程序设计-6逻辑表达式须注意逻辑表达式须注意vC+C+中,参加逻辑运算的对象可为任意类型的数据,中,参加逻辑运算的对象可为任意类型的数据,0 0为假,非为假,非0 0 为真。为真。5%2&p p5%2&p p 5 3&2|8 3&2|8 b)&(n=c d)a=1,b=2,c=2,d=4,m=1,n=1.问执行后问执行后m,n的值分别为多少?的值分别为多少?m
4、=0,n=1 程序设计 cs.sjtu 2011.9程序设计-8第第3章章 逻辑思维及分支程序设计逻辑思维及分支程序设计关系表达式关系表达式逻辑表达式逻辑表达式If语句语句Switch语句语句程序设计 cs.sjtu 2011.9程序设计-9条件检查与条件检查与if语句语句vif语句的格式语句的格式 if (条件测试)(条件测试)语句语句 if (条件测试)(条件测试)语句语句1 else 语句语句2v条件测试为条件测试为true时所执行的程序块叫做时所执行的程序块叫做then子子句,条件为句,条件为false时执行的语句叫做时执行的语句叫做else子句。子句。eg.if (grade=60)
5、if (grade=60)cout “passed”;cout=60)if (grade=60)cout “passed”;cout “passed”;else else cout “failed”;cout “failed”;程序设计 cs.sjtu 2011.9程序设计-10条件语句使用注意条件语句使用注意v条件的结果值应该是条件的结果值应该是 true true 或或 falsefalse,它们是,它们是C+C+中中boolbool类型的值类型的值v事实上,条件可为任意表达式,不一定是关系事实上,条件可为任意表达式,不一定是关系表达式。表达式。0 0 为为falsefalse,非,非 0
6、 0 为为truetrue。v常见的错误:条件测试是比较相等时,用一个常见的错误:条件测试是比较相等时,用一个等号等号,v合理的缩排,使程序结构更加清晰合理的缩排,使程序结构更加清晰程序设计 cs.sjtu 2011.9程序设计-11判断闰年的程序判断闰年的程序#include using namespace std;int main()int year;bool result;cout year;result=(year%4=0&year%100!=0)|year%400=0;if(result)cout year 是闰年是闰年 endl;else cout year 不是闰年不是闰年 en
7、dl;return 0;程序设计 cs.sjtu 2011.9程序设计-12if语句的嵌套语句的嵌套vif语句的语句的then子句或子句或else子句是子句是if语句,称语句,称为为if语句的嵌套语句的嵌套v歧义性:歧义性:if 语句可以没有语句可以没有else子句,如子句,如if(x 100)if(x 90)语句语句1 else if(x80)语句语句2 else 语句语句3 else 语句语句4;v配对原则:每个配对原则:每个else子句是和在它之前最子句是和在它之前最近的一个没有近的一个没有else子句的子句的if语句配对。语句配对。程序设计 cs.sjtu 2011.9程序设计-13缩
8、进对齐缩进对齐 v可以清晰地表示出层次可以清晰地表示出层次,便于程序员阅读,便于程序员阅读if(x 100)if(x 90)语句1 else if(x y)?x:y;v?:运算符用于输出。例如,想输出一个布尔变量?:运算符用于输出。例如,想输出一个布尔变量flag的值,的值,如果直接用如果直接用 cout flag;那么当那么当flag为为“真真”时,输出为时,输出为1;当;当flag为为“假假”时,输出为时,输出为0。如果我们想让如果我们想让flag为为“真真”时输出时输出true,为,为“假假”时输出时输出false,可以用,可以用if 语句语句 if (flag)cout “true”;
9、else cout “false”;看上去太罗嗦。但如果用?:运算符只需要一行看上去太罗嗦。但如果用?:运算符只需要一行 cout (flag?true:false)=90 A90score=80 B80score=70 C70score=60 Dscore=90:cout=80:cout=70:cout=60:cout D;break;default:cout=90 A90score=80 B80score=70 C70score=60 Dscore60 E表达式表达式=成绩成绩/10 switch(score/10)case 10:case 9:cout A;break;case 8:co
10、ut B;break;case 7:cout C;break;case 6:cout D;break;default:cout E;程序设计 cs.sjtu 2011.9程序设计-22计算机自动出四则运算计算题计算机自动出四则运算计算题 生成题目生成题目switch(题目类型题目类型)case 加法:显示题目,输入和的值,判断正确与否加法:显示题目,输入和的值,判断正确与否 case 减法:显示题目,输入差的值,判断正确与否减法:显示题目,输入差的值,判断正确与否 case 乘法:显示题目,输入积的值,判断正确与否乘法:显示题目,输入积的值,判断正确与否 case 除法:显示题目,输入商和余数
11、的值,判断正确与否除法:显示题目,输入商和余数的值,判断正确与否要求自动出要求自动出0-90-9之间的四则运算题,并批改结果之间的四则运算题,并批改结果程序设计 cs.sjtu 2011.9程序设计-23关键问题关键问题v如何让程序每次执行的时候都出不同的题目?如何让程序每次执行的时候都出不同的题目?v随机数生成器随机数生成器rand():能随机生成:能随机生成0到到RAND_MAX之间的整型数之间的整型数 v将生成的随机数映射到将生成的随机数映射到0-9之间:之间:Rand()%10rand()*10/(RAND_MAX +1)。v运算符的生成:用编码运算符的生成:用编码0-3表示四个运算符
12、。因表示四个运算符。因此题目的生成就是生成此题目的生成就是生成0-3之间的随机数。之间的随机数。程序设计 cs.sjtu 2011.9程序设计-24随机数的种子随机数的种子v计算机产生的随机数称为计算机产生的随机数称为伪伪随机数,它是根据一随机数,它是根据一个算法计算出来的。个算法计算出来的。v系统为每个程序、每次执行指定的随机数的种子系统为每个程序、每次执行指定的随机数的种子都是相同的,因此程序每次执行生成的随机数序都是相同的,因此程序每次执行生成的随机数序列都是相同的。列都是相同的。rand()种子种子1234812348程序设计 cs.sjtu 2011.9程序设计-25改变随机数的种子
13、改变随机数的种子v设置种子的函数设置种子的函数srand:srand(种子)(种子)v如何让程序每次执行时选择的种子都不一如何让程序每次执行时选择的种子都不一样呢样呢?v选择系统时间为种子:选择系统时间为种子:time(NULL)取当取当前的系统时间。前的系统时间。程序设计 cs.sjtu 2011.9程序设计-26#include /包含伪随机数生成函数包含伪随机数生成函数#include /包含取系统时间的函数包含取系统时间的函数#include using namespace std;int main()int num1,num2,op,result1,result2;/num1,num
14、2:操作数,操作数,op:运算符,运算符,result1,result2:结果结果 srand(time(NULL);/随机数种子初始化随机数种子初始化 num1=rand()*10/(RAND_MAX+1);/生成运算数生成运算数 num2=rand()*10/(RAND_MAX+1);/生成运算数生成运算数 op=rand()*4/(RAND_MAX+1);/生成运算符生成运算符 0-+,1-,2-*,3-/自动出题程序程序设计 cs.sjtu 2011.9程序设计-27switch(op)/最容易忘的是最容易忘的是switch下的大括号下的大括号!case 0:cout num1 +nu
15、m2 result1;if(num1+num2=result1)cout you are rightn;else cout you are wrongn;break;case 1:cout num1 -num2 result1;if(num1-num2=result1)cout you are rightn;else cout you are wrongn;break;case 2:cout num1 *num2 result1;if(num1*num2=result1)cout you are rightn;else cout you are wrongn;break;程序设计 cs.sjt
16、u 2011.9程序设计-28case 3:cout num1 /num2 result1;cout result2;if (num1/num2=result1)&(num1%num2=result2)cout you are rightn;else cout you are wrongn;break;return 0;程序设计 cs.sjtu 2011.9程序设计-29该程序的缺陷该程序的缺陷v每次执行只能出一道题每次执行只能出一道题v减法可能出现负值减法可能出现负值v除法可能出现除除法可能出现除0v结果太单调结果太单调程序设计 cs.sjtu 2011.9程序设计-30小结小结v本章主要介绍了计算机实现逻辑思维的机制。本章主要介绍了计算机实现逻辑思维的机制。主要包括两个方面:主要包括两个方面:如何表示一个逻辑判断如何表示一个逻辑判断如何根据逻辑判断的结果执行不同的处理如何根据逻辑判断的结果执行不同的处理v逻辑判断逻辑判断关系表达式实现关系表达式实现逻辑表达式逻辑表达式v根据逻辑判断执行不同的处理根据逻辑判断执行不同的处理if语句语句switch语句语句