程序的三种基本结构_第1页
程序的三种基本结构_第2页
程序的三种基本结构_第3页
程序的三种基本结构_第4页
程序的三种基本结构_第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

结构化程序设计基本思想:任何程序都可以用三种基本结构表示,限制使用无条件转移语句(goto)结构化程序:由三种基本结构反复嵌套构成的程序叫~优点:结构清晰,易读,提高程序设计质量和效率三种基本结构顺序结构ABAB流程图N-S图程序的三种基本结构

PAB真假PBA真假kA1A2AiAnk=k2k=k1k=knk=ki......二分支选择结构多分支选择结构选择结构当型循环结构直到型循环结构PA假真当P为真AAP真假A直到P为真注:A,B,A1….An可以是一个简单语句,也可以是一个基本结构循环结构

返回第5章选择语句5.1if条件语句5.2switch多分支选择语句5.3程序举例5.1if条件语句if语句是用来判定所给定的条件是否满足,根据判定的结果(真或假)决定执行给出的两种操作之一。5.1.1if语句的三种形式1.单分支选择语句的形式:if(表达式)语句

这种if语句的执行过程见图:0(N)表达式语句1(Y)main(){floatx,y;scanf(“%f”,&x);if(x>=0)y=2*x;if(x<0)y=3-x;printf(“y=%6.2f”,y);}任给a,b,c三个数,按从小到大的顺序输出。分析:(1)对于a,b任意两个数:若a<b,则输出a,b;否则输出b,a;

(2)对于三个数,有6种可能:

a<b<ca<c<bb<a<cb<c<ac<a<bc<b<a

(3)使用判断——交换法:

1.若a>b,则交换a和b,交换后a<b2.若a>c,则交换a和c,交换后a<c3.若b>c,则交换b和c,交换后b<c[例5.2」输入三个数,按由小到大顺序输出。main(){inta,b,c,temp;printf("Inputa,b,c:\n");scanf("%d,%d,%d",&a,&b,&c);if(a>b){temp=a;a=b;b=temp;}if(a>c){temp=a;a=c;c=temp;}if(b>c){temp=b;b=c;c=temp;}printf("%d,%d,%d",a,b,c);}

运行情况如下:3,7,11,3,72.双分支选择语句的形式:

if(表达式)语句1else语句2

见图:表达式语句1语句2真假main(){floatx,y;scanf(“%f”,&x);if(x<0)y=3-x;elsey=2*x;printf(“y=%6.2f”,y);}输入两个数,比较其大小,将较大的数输出。流程分析:(1)输入两个数据a,b;

(2)如果a>b则输出a;否则,输出b。#include<stdio.h>main(){floata,b;scanf(“%f,%f”,&a,&b);if(a>b)printf(“%f”,a);elseprintf(“%f”,b);}3.多分支选择语句的形式:if(表达式1)语句1elseif(表达式2)语句2elseif(表达式3)语句3elseif(表达式m)语句melse语句n

流程图表达式1FT表达式3FT表达式2FT表达式4FT语句4语句5语句3语句2语句1

写一个程序完成下列功能:

1.输入一个分数score2.score<60输出E3.60<=score<70输出D4.70<=score<80输出C5.80<=score<90输出B6.90<=score输出A多分支问题#include<stdio.h>main(){intscore;scanf(“%d”,&score);if(score<60)printf(“E”);elseif(score<70)printf(“D”);elseif(score<80)printf(“C”);elseif(score<90)printf(“B”);elseprintf(“A”);}程序如:if(a==b&&x==y)printf(“a=b,x=y”);if(3)printf(“OK”);if(‘a’)printf(“%d”,’a’);if后面的表达式类型任意语句可以是复合语句

if(x)

if(x!=0)if(!x)

if(x==0)例考虑下面程序的输出结果:#include<stdio.h>main(){intx,y;scanf(“%d,%d”,&x,&y);if(x>y)x=y;y=x;elsex++;y++;printf(“%d,%d\n”,x,y);}CompileError!说明:5.1.2一般形式:if(expr1)if(expr2)statement1elsestatement2elseif(expr3)statement3elsestatement4内嵌if内嵌ifif(expr1)if(expr2)statement1elsestatement2内嵌ifif(expr1)if(expr2)statement1elsestatement3

内嵌ifif(expr1)statement1elseif(expr3)statement3elsestatement4内嵌ifif语句嵌套/*ch4_4.c*/#include<stdio.h>main(){intx,y;printf("Enterintegerx,y:");scanf("%d,%d",&x,&y);if(x!=y)if(x>y)printf("X>Y\n");elseprintf("X<Y\n");elseprintf("X==Y\n");}运行:Enterintegerx,y:12,23

X<YEnterintegerx,y:12,6

X>YEnterintegerx,y:12,12

X==Y例输入两数并判断其大小关系缺省{}时,else总是和它上面离它最近的未配对的if配对if(……)if(……)if(……)else…...else…...else…...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~else正确配对方法5.2switch语句

switch语句是多分支选择语句。if语句只有两个分支可供选择,而实际问题中常常需要用到多分支的选择。例如,学生成绩分类(90分以为‘A’等,80~89分为‘B’等,70~79分为‘c’

等,……);人口统计分类(按年龄分为老、中、青、少、儿童);工资统计分类;银行存款分类;……等。当然这些都可以用嵌套的if语句或多分支来处理,但如果分支较多,则嵌套的if语句层数多,程序冗长而且可读性降低。C语言提供switch语句直接处理多分支选择,它的一般形式如下:

switch(表达式)

{case常量表达式1:语句1case常量表达式2:语句2case常量表达式i:语句ndefault:语句n+1}

首先计算表达式的值,然后依次与常量表达式

i(i=1,2,……,n)比较。若表达式的值与某一个常量表达式,如j(1≤j≤n)相等,则执行语句j。

②若表达式的值与所有的常量表达式i(i=1,2,……,n)均不相等,则执行defau1t后面的语句n+1。功能语句中的表达式可以是整型或字符型、枚举型。常量表达式i必须与表达式类型一致(整型与字符型通用)。i仅起语句标号作用,不做求值判断。语句结构中各个case后常量表达式的值必须互不相同;否则执行时将出现矛盾。各个case的出现次序不影响执行结果。例如,可以先出现case‘D’:…,然后是case‘A’:……default一般出现在所有case之后,也可以出现在case之前或两个case之间,default也可以缺省。为了在执行完一个case分支后能跳出switch多分支选择语句,可在case分支结束后,插入一个break语句。若有break语句,就从此break语句跳出break所在的当前结构;若无break语句,执行该语句后,流程控制转移到下一个分支:继续执行这一个分支的语句,一直到最后一个语句执行完。下一页注意switch(i){case1:printf(″A\n″);

case3:printf(″C\n″);case4:printf(″D\n″);default:printf(″E\n″);}

假设i=3时,则会从i=3时做起始语句。运行结果见右图。如果给每条语句加上break这样就只执行一条语句。C

D

E下一页看下面的例子运行结果case2:printf(″B\n″);如果多种情况需要共用一个执行语句,可用case的常量表达式多种情况列出,最后一种情况后,才放执行的语句。

case后面的语句可以是一条语句,也可以是复合语句,还可以是花括弧括起来的几条语句,还可以是空语句。有多条语句时会顺序执行完所有语句。下一页说明编程:根据输入的学生的成绩判断等级。当成绩score≥90时为A等;成绩70≤score<90为B等;成绩60≤score<70为C等;成

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论