C语言复习资料4_第1页
C语言复习资料4_第2页
C语言复习资料4_第3页
C语言复习资料4_第4页
C语言复习资料4_第5页
已阅读5页,还剩55页未读 继续免费阅读

下载本文档

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

文档简介

C++语言程序设计(4)第4章选择结构程序设计4.1关于算法算法的概念做任何事情都有一定的步骤。为解决一个问题而采取的方法和步骤,就称为算法。计算机算法:计算机能够执行的算法。计算机算法可分为两大类:数值运算算法:求解数值;非数值运算算法:事务管理领域。一个程序应包括两个方面的内容:对数据的描述:数据结构(datastructure)对操作的描述:算法(algorithm)著名计算机科学家沃思提出一个公式:数据结构+算法=程序

数据结构+算法+程序设计方法+语言工具完整的程序设计应该是:简单算法举例

例1求1×2×3×4×5。最原始方法:步骤1:先求1×2,得到结果2。步骤2:将步骤1得到的乘积2乘以3,得到结果6。步骤3:将6再乘以4,得24。步骤4:将24再乘以5,得120。这样的算法虽然正确,但太繁。

改进的算法:S1:使t=1S2:使i=2S3:使t×i,乘积仍然放在在变量t中,可表示为t×i→tS4:使i的值+1,即i+1→iS5:如果i≤5,返回重新执行步骤S3以及其后的S4和S5;否则,算法结束。如果计算100!只需将S5:若i≤5改成i≤100即可。如果求1×3×5×7×9×11,算法也只需做很少的改动:S1:1→tS2:3→iS3:t×i→tS4:i+2→tS5:若i≤11,返回S3,否则,结束。该算法不仅正确,而且是计算机较好的算法,因为计算机是高速运算的自动机器,实现循环轻而易举。

例2

有50个学生,要求将他们之中成绩在80分以上者打印出来。如果,n表示学生学号,ni表示第个学生学号;g表示学生成绩,gi表示第个学生成绩;则算法可表示如下:S1:1→iS2:如果gi≥80,则打印ni和gi,否则不打印S3:i+1→iS4:若i≤50,返回S2,否则,结束。如果包括这个输入数据的部分,流程图为

例3

判定2000—2500年中的每一年是否闰年,将结果输出。闰年的条件:能被4整除,但不能被100整除的年份;能被100整除,又能被400整除的年份;

设y为被检测的年份,则算法可表示如下:S1:2000→yS2:若y不能被4整除,则输出y“不是闰年”,然后转到S6S3:若y能被4整除,不能被100整除,则输出y“是闰年”,然后转到S6S4:若y能被100整除,又能被400整除,输出y“是闰年”否则输出y“不是闰年”,然后转到S6S5:输出y“不是闰年”。S6:y+1→yS7:当y≤2500时,返回S2继续执行,否则,结束。算法的特性

有穷性:一个算法应包含有限的操作步骤而不能是无限的。确定性:算法中每一个步骤应当是确定的,而不能应当是含糊的、模棱两可的。有零个或多个输入。有一个或多个输出。有效性:算法中每一个步骤应当能有效地执行,并得到确定的结果。怎样表示一个算法

(1)用自然语言表示算法除了很简单的问题,一般不用自然语言表示算法。(2)用流程图表示算法流程图表示算法,直观形象,易于理解。(3)用N-S流程图表示算法

1973年美国学者提出了一种新型流程图:N-S流程图。顺序结构:选择结构:循环结构:N-S图表示算法的优点比文字描述直观、形象、易于理解;比传统流程图紧凑易画。尤其是它废除了流程线,整个算法结构是由各个基本结构按顺序组成的,N--S流程图中的上下顺序就是执行时的顺序。用N--S图表示的算法都是结构化的算法,因为它不可能出现流程无规律的跳转,而只能自上而下地顺序执行。(4)用伪代码表示算法

伪代码使用介于自然语言和计算机语言之间的文字和符号来描述算法。4.2条件判断

4.2.1关系运算符和关系表达式1.关系运算符及其优先次序<(小于)<=(小于或等于)>(大于)>=(大于或等于)==(等于)!=(不等于)优先级相同(高)优先级相同(低)说明:关系运算符的优先级低于算术运算符关系运算符的优先级高于赋值运算符优先级举例c>a+b

等价于c>(a+b)a>b==c等价于(a>b)==ca==b<c等价于a==(b<c)a=b>c等价于a=(b>c)2.关系表达式用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符表达式)接起来的式子,称关系表达式例:a>b,a+b>b+c,(a=3)>(b=5),’a’<‘b’,(a>b)>(b<c)关系表达式的值是一个逻辑值,即“真”或“假”。例:关系表达式a>b的值为“真”,那表达式的值就为1。C语言中没有专用的逻辑值,1代表真,0代表假例子a=3,b=2,c=1;a>b值为1(a>b)==c值为1b+c<a值为0d=a>b;=>d值为1f=a>b>c;(“>”运算符自左向右结合,“a>b”值为1,“1>c”值为0,f值为0)1.逻辑运算符及其优先次序(1)&&(逻辑与)相当于其他语言中的AND(2)||(逻辑或)相当于其他语言中的OR(3)!(逻辑非)相当于其他语言中的NOT例:a&&b若a,b为真,则a&&b为真。

a||b若a,b之一为真,则a||b为真。!a若a为真,则!a为假。优先次序:!(非)->&&()->||()逻辑运算符中的“&&”和“||”低于关系运算符,“!”高于算术运算符

4.2.2逻辑运算符和逻辑表达式2.逻辑表达式用逻辑运算符将关系表达式或逻辑量连接起来的式子就是逻辑表达式。逻辑表达式的值应该是一个逻辑量“真”或“假”。例:设a=4,b=5:!a的值为0a&&b的值为1a||b的值为1!a||b的值为14&&0||2的值为1任何非零的数值被认作“真”例:5>3&&8<4-!0

自左向右运算

1&&0逻辑值为08<3逻辑值为04-1值为3!0逻辑值为15>3逻辑值为1表达式值为0在逻辑表达式的求解中,并不是所有的逻辑运算符都要被执行。(1)a&&b&&c只有a为真时,才需要判断b的值,只有a和b都为真时,才需要判断c的值。(2)a||b||c只要a为真,就不必判断b和c的值,只有a为假,才判断b。a和b都为假才判断c例:(m=a>b)&&(n=c>d)当a=1,b=2,c=3,d=4,m和n的原值为1时,由于“a>b”的值为0,因此m=0,而“n=c>d”不被执行,因此n的值不是0而仍保持原值1。用逻辑表达式来表示闰年的条件能被4整除,但不能被100整除。能被4整除,又能被400整除。?答

(year%4==0&&year%100!=0)||year%400==0案

值为真(1)是闰年,否则为非闰年。

4.3if语句1.if语句的三种基本形式(1)if(表达式)语句例:

if(x>y)printf(“%d”,x);表达式语句真(非0)假(0)(2)if(表达式)语句1else语句2例:

if(x>y)printf(“%d”,x);elseprintf(“%d”,y);

条件

语句1

语句2YN

(3)if(表达式1)语句1elseif(表达式2)语句2elseif(表达式3)语句3……elseif(表达式m)语句melse语句n

例:

if(number>500)cost=0.15;elseif(number>300)cost=0.10;elseif(number>100)cost=0.075;elseif(number>50)cost=0.05;elsecost=0;

4.3if语句

说明:(1)3种形式的if语句中在if后面都有表达式,一般为逻辑表达式或关系表达式。(2)第二,第三种形式的if语句中,在每个

else前面有一个分号,整个语句结束处有一个分号。

(3)else不是一个独立的语句,一定要和if配合使用;(4)在if和else后面可以只含有一个内嵌的操作语句,也可以由多个操作语句,此时用花括号将几个语句括起来成为一个复合语句。if(…){…}(无需加分号)else{…}

例子例4.1输入两个实数,按代数值由小到大的顺序输出这两个数。

#include<stdio.h>

voidmain()

{floata,b,t;

scanf(″%f,%f″,&a,&b);

if(a>b)

{t=a;

a=b;

b=t;}

printf(″%5.2f,%5.2f\n″,a,b);}

yna>bT=aA=bB=t

运行结果:3.6,-3.2回车-3.20,_3.60

例4.2输入三个数a,b,c,要求按由小到大的顺序输出。Ifa>b将a和b对换Ifa>c将a和c对换Ifb>c将b和c对换a>ba>cb>ca和b交换a和c交换c和b交换yyynn

#include<stdio.h>

voidmain()

{

floata,b,c,t;

scanf(″%f,%f,%f″,&a,&b,&c);

if(a>b)

{t=a;a=b;b=t;}

if(a>c)

{t=a;a=c;c=t;}

if(b>c)

{t=b;b=c;c=t;}

printf("%5.2f,%5.2f,%5.2f\n",a,b,c);

}

2.if语句的嵌套在if语句中又包含一个或多个if语句称为if语句的嵌套。形式:if()

if()语句1 else语句2else

if()语句3 else语句4内嵌if

匹配规则:else总是与它上面的,最近的,统一复合语句中的,未配对的if语句配对。例:if()

if()语句1else

if()语句2else语句3例:if() {if()语句1}else

if()语句2else语句3当if和else数目不同时,可以加花括号来确定配对关系。

-1(x<0)例4.3有一个函数y=0(x=0),编一程序,输入一个x值,输出y值。1(x>0)算法1:算法1:

输入x输入x

若x<0,则y=-1若x<0,则y=-1

若x=0,则y=0否则: 若x>0,则y=1若x=0,则y=0

输出y若x>0,则y=1

输出y

#include<stdio.h>voidmain(){

intx,y;

scanf(“%d”,&x);{

程序段}

printf(“x=%d,y=%d\n”,x,y);}

上例中的程序段有四个,请判断哪个是正确的?程序1:程序2:

if(x<0)if(x>=0)y=-1;if(x>0)y=1;elseelsey=0;

if(x==0)y=0;elsey=-1;elsey=1;程序3:程序4:y=-1;y=0;

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

if(x>0)y=1;if(x>0)y=1;elsey=0;elsey=-1;正确正确程序3和4错误,本意与实际配对关系不符合4.4.3条件运算符格式:表达式1?表达式2∶表达式3功能:判断表达式1的值,如果成立就执行表达式2,否则就执行表达式3使用场合:若在if语句中,当被判别的表达式的值为“真”或“假”时,都执行一个赋值语句且向同一个变量赋值时,可以用一个条件运算符来处理。

例:

if(a>b)max=a;elsemax=b;当a>b时将a的值赋给max,当a≤b时将b的值赋给max,可以看到无论a>b是否满足,都是向同一个变量赋值。可以用下面的条件运算符来处理:max=(a>b)?a∶b;

说明:(1)条件运算符的执行顺序:先求解表达式1,若为非0(真)则求解表达式2,此时表达式2的值就作为整个条件表达式的值。若表达式1的值为0(假),则求解表达式3,表达式3的值就是整个条件表达式的值。

(2)条件运算符优先级高于赋值运算符,低于关系运算符和算术运算符。

max=(a>b)?a:b

max=a>b?a:b

a>b?a:b+1a>b?a:(b+1)

(3)条件运算符的结合方向为“自右至左”。

a>b?a:c>d?c:d相当于a>b?a:(c>d?c:d)(4)“表达式2”和“表达式3”不仅可以是数值表达式,还可以是赋值表达式或函数表达式。a>b?(a=100):(b=100)a>b?printf(“%d”,a):printf(“%d”,b)

(5)条件表达式中,表达式1的类型可以与表达式2和表达式3的类型不同。x?’a’:’b’表达式2和表达式3类型也可以不一样,例如x>y?1:1.5当x≤y,表达式值为1.5,当x>y时,值应为1,但由于1.5为实型,所以将1转换为1.0

例4.4输入一个字符,判别它是否大写字母,如果是,将它转换成小写字母;如果不是,不转换。然后输出最后得到的字符。

#include<stdio.h>

voidmain()

{charch;

scanf("%c",&ch);

ch=(ch>='A'&&ch<='Z')?(ch+32):ch;

printf("%c\n",ch);

}

如果字符变量ch的值为大写字母,则条件表达式的值为(ch+32),即相应的小写字母。如果ch的值不是大写字母,则条件表达式的值为ch,即不进行转换。

4.4switch语句switch语句的格式:switch

(表达式){case常量表达式1:语句1

case常量表达式2:语句2

…case常量表达式n:语句n

default:语句n+1}

例:要求按照考试成绩的等级输出百分制分数段,用switch语句实现:

switch(grade){case′A′∶printf(″85~100\n″);

case′B′∶printf

(″70~84\n″);

case′C′∶printf

(″60~69\n″);

case′D′∶printf

(″<60\n″);

default∶(printf″error\n″);}

说明:

switch后面括弧内的“表达式”,ANSI标准允许它为任何类型。(2)

当表达式的值与某一个case后面的常量表达式的值相等时,就执行此case后面的语句,若所有的case中的常量表达式的值都没有与表达式的值匹配的,就执行default后面的语句。(3)每一个case的常量表达式的值必须互不相同,否则就会出现互相矛盾的现象(对表达式的同一个值,有两种或多种执行方案)。

(4)各个case和default的出现次序不影响执行结果。例如,可以先出现“default:…”,再出现“case′D′:…”,然后是“case′A′:…”。(5)

执行完一个case后面的语句后,流程控制转移到下一个case继续执行。“case常量表达式”只是起语句标号作用,并不是在条件判断。在执行switch语句时,根据switch后面表达式的值找到匹配的入口标号,就从此标号开始执行下去,不再进行判断。应该在执行一个case分支后,可以用一个

break语句来终止switch语句的执行。

(6)多个可以共用一组执行语句。

程序举例例4.5写程序,判断某一年是否闰年。 用下图来表示判断闰年的算法。

4.5程序举例#include<stdio.h>

voidmain()

{intyear,leap;

scanf("%d",&year);

if(year%4==0)

{if(year%100==0)

{if(year%400==0)leap=1;

elseleap=0;}

elseleap=1;}

elseleap=0;

if(leap)printf("%dis",year);

elseprintf("%disnot",year);

printf("aleapyear.\n");}if(year%4!=0)leap=0;elseif(year%100!=0)leap=1;elseif(year%400!=0)leap=0;elseleap=1;运行情况:

1989↙

1989isnotaleapyear.

2000↙

2000isaleapyear.程序举例例4.6求ax2+bx+c=0方程的解。基本的算法:①a=0,不是二次方程。②b2-4ac=0,有两个相等实根。③b2-4ac>0,有两个不等实根。④b2-4ac<0,有两个共轭复根。

#include<stdio.h>

#include<math.h>

voidmain()

{floata,b,c,disc,x1,x2,realpart,imagpart;

scanf("%f,%f,%f",&a,&b,&c);

printf("theequation");

if(fabs(a)<=1e-6)

printf("isnotaquadratic\\n");

else

{disc=b*b-4*a*c;

if(fabs(disc)<=1e-6)

printf("hastwoequalroots:%8.4f\n",-b/(2*a));

elseif(disc>1e-6)

{x1=(-b+sqrt(disc))/(2*a);

x2=(-b-sqrt(disc))/(2*a);

printf(″hasdistinctrealroots:%8.4fand%8.4f\n″,x1,x2);

}

else

{realpart=-b/(2*a);

imagpart=sqrt(-disc)/(2*a);

printf(″hascomplexroots∶\n″);

printf(″%8.4f+%8.4fi\n″,realpart,imagpart);

printf(″%8.4f-%8.4fi\n″,realpart,imagpart);

}

}}

程序举例例4.7运输公司对用户计算运费。路程(s)越远,每公里运费越低。标准如下:s<250km没有折扣250≤s<500

温馨提示

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

评论

0/150

提交评论