1、结构化程序设计 基本思想:任何程序都可以用三种基本结构表示,限制使用无条件转移语句(goto) 结构化程序:由三种基本结构反复嵌套构成的程序叫 优点:结构清晰,易读,提高程序设计质量和效率 三种基本结构 顺序结构,程序的三种基本结构,二分支选择结构,多分支选择结构,选择结构,当型循环结构,直到型循环结构,注:A,B,A1.An可以是一个简单语句,也可以是一个基本结构,循环结构,返回,第5章 选择语句,5.1 if 条件语句 5.2 switch多分支选择语句 5.3 程序举例,5.1 if条件语句 if语句是用来判定所给定的条件是否满足,根据判定的结果(真或假)决定执行给出的两种操作之一。 5
2、.1.1 if语句的三种形式 1单分支选择语句的形式: if(表达式) 语句这种if语句的执行过程见图:,main( ) float x , y;scanf(“%f ”, ,任给a,b,c三个数,按从小到大的顺序输出。分析: (1)对于a,b任意两个数:若ab,则交换a和b,交换后ac,则交换a和c,交换后ac,则交换b和c,交换后bc,例52输入三个数,按由小到大顺序输出。 main( ) int a,b,c,temp; printf(“Input a,b,c:n“); scanf(“%d,%d,%d“, 运行情况如下: 3,7,11, 3, 7,2双分支选择语句的形式: if(表达式) 语
3、句1 else 语句2见图:,main() float x , y;scanf(“%f ”, ,输入两个数, 比较其大小, 将较大的数输出。,流程分析: (1) 输入两个数据a,b ; (2) 如果ab 则输出a ;否则,输出b。 #include main( ) float a, b;scanf(“%f, %f”, ,3多分支选择语句的形式: if (表达式1) 语句1else if (表达式2) 语句2else if(表达式3) 语句3else if (表达式m) 语句melse 语句n流程图,写一个程序完成下列功能:1. 输入一个分数score2 .score60 输出 E3 .60=s
4、core 70 输出 D4. 70=score 80 输出 C5 .80=score 90 输出 B6 .90=score 输出 A,多分支问题,#include main( ) int score;scanf(“%d”, ,程序,如:if(a=b,if后面的表达式类型任意,语句可以是复合语句if(x) if(x!=0)if(!x) if(x=0),例 考虑下面程序的输出结果: #include main() int x,y;scanf(“%d,%d”, ,Compile Error!,说明:,5.1.2 一般形式:,if语句嵌套,/*ch4_4.c*/ #include main() int
5、 x,y;printf(“Enter integer x,y:“);scanf(“%d,%d“, ,运行:Enter integer x,y:12,23XYEnter integer x,y:12,12X=Y,例 输入两数并判断其大小关系,缺省 时,else总是和它上面离它最近的未配对的if配对,if else 配对原则:,例: if (a=b)if(b=c)printf(“a=b=c”);elseprintf(“a!=b”);,修改: if (a=b) if(b=c)printf(“a=b=c”);elseprintf(“a!=b”);,实现if else 正确配对方法:加 ,实现if el
6、se 正确配对方法,5.2 switch语句switch语句是多分支选择语句。if语句只有两个分支可供选择,而实际问题中常常需要用到多分支的选择。例如,学生成绩分类(90分以为A等,8089分为B等,7079分为c 等,);人口统计分类(按年龄分为老、中、青、少、儿童);工资统计分类;银行存款分类;等。当然这些都可以用嵌套的if语句或多分支来处理,但如果分支较多,则嵌套的if语句层数多,程序冗长而且可读性降低。C语言提供switch语句直接处理多分支选择,它的一般形式如下:switch (表达式) case 常量表达式1:语句1;case 常量表达式2:语句2;case 常量表达式i:语句n;
7、default :语句n+1;,首先计算表达式的值,然后依次与常量表达式 i(i=1,2,n)比较。若表达式的值与某一个常量表达式, 如 j (1 j n)相等,则执行语句 j。 若表达式的值与所有的常量表达式 i(i=1,2,n)均不相等,则执行defau1t后面的语句 n+1。,功能,语句中的表达式可以是整型或字符型、枚举型。常量表达式 i 必须与表达式类型一致(整型与字符型通用)。 i 仅起语句标号作用,不做求值判断。 语句结构中各个case后常量表达式的值必须互不相同;否则执行时将出现矛盾。 各个case的出现次序不影响执行结果。例如,可以先出现caseD:,然后是caseA: def
8、ault一般出现在所有case之后,也可以出现在case之前或两个case之间,default也可以缺省。 为了在执行完一个case分支后能跳出switch多分支选择语句,可在case分支结束后,插入一个break语句。若有break语句,就从此break语句跳出break所在的当前结构;若无break语句,执行该语句后,流程控制转移到下一个分支: 继续执行这一个分支的语句,一直到最后一个语句执行完。,下一页,注意,switch ( i ) case 1:printf(An); case 3:printf( Cn);case 4:printf(Dn);default:printf(En); ,
9、假设i=3时,则会从i=3时做起始语句。运行结果见右图。如果给每条语句加上break这样就只执行一条语句。,C D E,下一页,看下面的例子,运行结果,case 2: printf ( Bn );,如果多种情况需要共用一个执行语句,可用case的常量表达式多种情况列出,最后一种情况后,才放执行的语句。 case后面的语句可以是一条语句,也可以是复合语句,还可以是花括弧括起来的几条语句,还可以是空语句。有多条语句时会顺序执行完所有语句。,下一页,说明,编程:根据输入的学生的成绩判断等级。 当成绩score 90时为 A等; 成绩70score 90 为B等; 成绩60score 70 为C等;
10、成绩score 60 为D等; (score 为整数)。,分析: 设score为整型数,在score90 的范围内,score可能取100, 99,.,90,利用两个整数相除,结果自动取整的特性score score/10 90 10, 97089 7 , 86069 660以下 default score和 score /10 有如上对应关系:,下一页,例如,因此,可以用score /10的值来确定分支,#include main( ) /*用switch 语句评级 */ int score; scanf(“%d“ , ,程序,返回,作 业,编程实现对4个实数排序 输入整数a、b,若a2+b2大于100,则输出百位以上的数字,否则输出两数之和。 输入三个整数,判断能否构成一个三角形,能则输出YES,否则输出NO。,