第四章
本章要点
关系表达式
逻辑表达式
选择结构程序设计
主要内容
4.1 关于算法
4.2 条件判断
4.3 用 if语句实现选择结构
4.4 利用 switch语句实现多分支选择结构
4.5 程序举例
4.1 关于算法
4.1.1 算法的概念
一个程序由两部分构成,
⑴ 数据结构。程序中数据的类型和数据的组织形式,
是对数据的描述。
⑵算法。操作步骤,是对操作的描述。
计算机算法分为两类:
⑴数值运算算法。目的是求数解值。
⑵非数值运算算法。应用较数值运算算法来说更广泛。
4.1 关于算法
4.1.2 怎样表示算法
算法的表示方法:
⑴用自然语言表示。用自然语言表示通俗易懂,但文字冗长,容易出现歧义性。
⑵ 用流程图表示算法 。用图形表示算法,直观形象,
易于理解。 (图 2-3)
4.2 条件判断
4.2.1 关系运算和关系表达式
1.关系运算符及其优先次序
1,< (小于 )
2,<= (小于或等于 )
3,> (大于 )
4,>= (大于或等于 )
5,== (等于 )
6,!= (不等于 )
优先级相同(高)
优先级相同(低)
说明:
关系运算符的优先级低于算术运算符关系运算符的优先级高于赋值运算符
4.2 条件判断
4.2.1 关系运算和关系表达式
2.关系表达式
用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符表达式)
接起来的式子,称关系表达式例,a>b,a+b>b+c,(a=3)>(b=5),?a?<?b?,(a>b)>(b<c)
关系表达式的值是一个逻辑值,即“真”或“假”。
例,关系表达式” a>b”的值为“真”,表达式的值为 1。
C语言中没有专用的逻辑值,1代表真,0代表假
4.2 条件判断
4.2.2 逻辑运算符和逻辑表达式
1.逻辑运算符及其优先次序
1,&& (逻辑与 ) 相当于其他语言中的 AND
2,|| (逻辑或 ) 相当于其他语言中的 OR
3,! (逻辑非 ) 相当于其他语言中的 NOT
例,a&&b 若 a,b为真,则 a&&b为真。
a||b 若 a,b之一为真,则 a||b为真。
! a 若 a为真,则 !a为假。优先次序:
! (非 )->&&()->||()
逻辑运算符中的,&&”和,||”低于关系运算符,,!”高于算术运算符
4.2 条件判断
4.2.2 逻辑运算符和逻辑表达式
2.逻辑表达式
用逻辑运算符将关系表达式或逻辑量连接起来的式子就是逻辑表达式
逻辑表达式的值应该是一个逻辑量,真,或,假,。
例,设 a=4,b=5:
!a的值为 0 a&&b的值为 1
a||b的值为 1 !a||b的值为 1
4&&0||2的值为 1
任何非零的数值被认作“真”
4.2 条件判断
4.2.2 逻辑运算符和逻辑表达式例,5>3&&8<4-!0
自左向右运算
1&&0逻辑值为 0 8<3逻辑值为 0
4-1值为 3!0逻辑值为 15>3逻辑值为 1
表达式值为 0
4.2 条件判断
4.2.2 逻辑运算符和逻辑表达式在逻辑表达式的求解中,并不是所有的逻辑运算符都要被执行。
(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.2 条件判断
4.2.2 逻辑运算符和逻辑表达式用逻辑表达式来表示闰年的条件
能被 4整除,但不能被 100整除。
能被 4整除,又能被 400整除答 (year%4==0&&year%100!=0)||year%400==0
案 值为真 (1)是闰年,否则为非闰年。
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式
If语句的三种基本形式
(1)if (表达式) 语句例:
if(x>y) printf(“%d”,x);
表达式语句真(非 0) 假
( 0)
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式
(2)if(表达式 ) 语句 1
else 语句 2
例:
if (x>y) printf(“%d”,x);
else printf(“%d”,y);
条件语句 1 语句 2
Y N
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式
(3)if(表达式 1)语句 1
else if(表达式 2)语句 2
else if(表达式 3)语句 3
……
else if(表达式 m)语句 m
else 语句 n
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式例:
if (number>500)cost=0.15;
else if(number>300)cost=0.10;
else if(number>100)cost=0.075;
else if(number>50)cost=0.05;
else cost=0;
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式说明:
(1).3种形式的 if语句中在 if后面都有表达式,
一般为逻辑表达式或关系表达式。
(2).if语句中有内嵌语句,每个内嵌语句必须以分号结束。
(3).else语句不能作为语句单独使用,它是if语句的一部分,必须与if配对使用。
(4).在 if和 else后面可以只含有一个内嵌的操作语句,也可以由多个操作语句,此时用花括号将几个语句括起来成为一个复合语句。
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式例 4.1 输入两个实数,按代数值由小到大的顺序输出这两个数。
#include<stdio.h>
void main()
{float a,b,t;
scanf(“%f,%f”,&a,&b);
if(a>b)
{t=a;
a=b;
b=t;}
printf(“%5.2f,%5.2f \n”,a,b); }
y
n
a>b
T=a
A=b
B=t
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式例 4.2 输入三个数 a,b,c,要求按由小到大的顺序输出。
If a>b 将 a和 b对换
If a>c 将 a和 c对换
If b>c 将 b和 c对换
a>b
a>c
b>c
a和 b交换 a和 c交换 c和 b交换
y
y
y
n
n
4.3 用 if语句实现选择结构
4.3.1 if语句的 3种形式
#include <stdio.h>
void main ( )
{ float a,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);
}
4.3 用 if语句实现选择结构
4.3.2 if语句的嵌套
在 if语句中又包含一个或多个 if语句称为 if语句的嵌套。
形式:
If()
if() 语句 1
else 语句 2
Else
if() 语句 3
else 语句 4
内嵌 if
4.3 用 if语句实现选择结构
4.3.2 if语句的嵌套匹配规则:
Else总是与它上面的,最近的,统一复合语句中的,未配对的 if语句配对。
例:
If()
if() 语句 1
else
if() 语句 2
else 语句 3
例:
If()
{if() 语句 1}
else
if() 语句 2
else 语句 3
当 if和 else数目不同时,可以加 花括号 来确定配对关系。
4.3 用 if语句实现选择结构
4.3.2 if语句的嵌套 -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
4.3 用 if语句实现选择结构
4.3.2 if语句的嵌套
#include<stdio.h>
void main()
{
int x,y;
scanf(“%d”,&x);
{
程序段
}
printf(“x=%d,y=%d\n”,x,y);
}
4.3 用 if语句实现选择结构
4.3.2 if语句的嵌套上例中的程序段有四个,请判断哪个是正确的?
程序 1,程序 2:
If(x<0) if(x>=0)
Y=-1; if(x>0) y=1;
Else else y=0;
If(x==0) y=0; else y=-1;
Else y=1;
程序 3,程序 4:
Y=-1; y=0;
If(x!=0) if(x>=0)
If(x>0) y=1; if(x>0) y=1;
Else y=0; Else y=-1;
正确 正确
4.3 用 if语句实现选择结构
4.3.3 条件运算符和条件表达式
条件表达式用来处理if语句中判别的表达式的值无论为,真,或,假,都要向同一个变量赋值执行一个赋值语句的情况。
格式,表达式1?表达式2 ∶ 表达式3
功能,判断 表达式 1的值,如果成立就执行 表达式 2,否则就执行 表达式 3
使用场合:若在if语句中,当被判别的表达式的值为,真,或,假,时,都执行一个赋值语句且向 同一个变量 赋值时,可以用一个条件运算符来处理。
4.3 用 if语句实现选择结构
4.3.3 条件运算符和条件表达式例:
if (a>b) max =a;
else max=b;
当 a>b时将 a的值赋给 max,当 a≤b 时将 b的值赋给 max,
可以看到无论 a>b是否满足,都是向同一个变量赋值。
可以用下面的条件运算符来处理:
max=( a>b )? a ∶ b ;
4.3 用 if语句实现选择结构
4.3.3 条件运算符和条件表达式说明:
(1).条件运算符的执行顺序:先求解表达式1,若为非0(真)
则求解表达式2,此时表达式2的值就作为整个条件表达式的值。若表达式1的值为0(假),则求解表达式3,表达式3的值就是整个条件表达式的值。
(2).条件运算符优先级高于赋值运算符,低于关系运算符和算术运算符。
(3).条件运算符的结合方向为,自右至左,。
(4).“表达式 2”和,表达式 3”不仅可以是数值表达式,还可以是赋值表达式或函数表达式。
(5).条件表达式中,表达式1的类型可以与表达式2和表达式3的类型不同。
4.3 用 if语句实现选择结构
4.3.3 条件运算符和条件表达式例 4.4输入一个字符,判别它是否大写字母,如果是,将它转换成小写字母;如果不是,不转换。然后输出最后得到的字符。
#include <stdio.h>
void main ( )
{ char ch;
scanf("%c",& ch);
ch=(ch>='A'&& ch<='Z')?(ch+32):ch;
printf("%c\n",ch);
}
如果字符变量 ch的值为大写字母,
则条件表达式的值为(ch+3
2),即相应的小写字母。如果 ch
的值不是大写字母,则条件表达式的值为ch,即不进行转换。
4.4 利用 switch语句实现多分支选择结构
switch语句的格式:
switch (表达式)
{ case 常量表达式1:语句1
case 常量表达式2:语句2

case 常量表达式n:语句n
default,语句n+1

4.4 利用 switch语句实现多分支选择结构例,
要求按照考试成绩的等级输出百分制分数段,用
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 ″ );

4.4 利用 switch语句实现多分支选择结构说明:
switch后面括弧内的,表达式,,ANSI
标准允许它为任何类型。
(2) 当表达式的值与某一个 case后面的常量表达式的值相等时,就执行此 case后面的语句,若所有的 case中的常量表达式的值都没有与表达式的值匹配的,就执行 default后面的语句。
(3) 每一个 case的常量表达式的值必须互不相同,
否则就 会出现互相矛盾的现象(对表达式的同一个值,有两种或多种执行方案)。
4.4 利用 switch语句实现多分支选择结构
(4) 各个 case和 default的出现次序不影响执行结果。例如,可以先出现,default,…”,再出现
,case ′D ′,…”,然后是,case′A ′,…” 。
(5) 执行完一个 case后面的语句后,流程控制转移到下一 个 case继续执行。,case常量表达式”只是起语句标号作用,并不是在条件判断。在执行 switch
语句时,根据 switch后面表达式的值 找到匹配的入口标号,就从此标号开始执行下去,不再进行判断。 应该在执行一个 case分支后,可以用一个
break语句来终止 switch语句的执行。
(6) 多个可以共用一组执行语句。
4.5 程序举例例 4.5写程序,判断某一年是否闰年。
用下图来表示判断闰年的算法。
4.5 程序举例
#include <stdio.h>
void main()
{int year,leap;
scanf("%d",&year);
if (year%4==0)
{if (year%100==0)
{if (year%400==0) leap=1;
else leap=0;}
else leap=1;}
else leap=0;
if (leap) printf("%d is ",year);
else printf("%d is not ",year);
printf("a leap year.\n");}
if(year%4!=0) leap=0;
else if(year%100!=0)
leap=1;
else if(year%400!=0)
leap=0;
else leap=1;
运行情况:
1989 ↙
1989 is not a leap year,
2000 ↙
2000 is a leap year,
4.5 程序举例例 4.6 求a+bx+c=0方程的解。
基本的算法:
① a=0,不是二次方程。
② -4ac=0,有两个相等实根。
③ -4ac>0,有两个不等实根。
④ -4ac<0,有两个共轭复根。
4.5 程序举例
#include <stdio.h>
#include <math.h>
void main ( )
{float a,b,c,disc,x1,x2,realpart,imagpart;
scanf("%f,%f,%f",&a,&b,&c);
printf("the equation ");
if(fabs(a)<=1e-6)
printf("is not a quadratic\\n");
else
{ disc=b*b-4*a*c;
if(fabs(disc)<=1e-6)
printf("has two equal roots:%8.4f\n",-
b/(2*a));
4.5 程序举例
else if(disc>1e-6)
{x1=(-b+sqrt(disc))/(2*a);
x2=(-b-sqrt(disc))/(2*a);
printf(,has distinct real roots:%8.4f and
%8.4f\n”,x1,x2);
}
else
{realpart=-b/(2*a);
imagpart=sqrt(-disc)/(2*a);
printf(,has complex roots∶ \n” );
printf(,%8.4f+%8.4fi\n”,realpart,imagpart);
printf(,%8.4f-%8.4fi\n”,realpart,imagpart);
}
}}
运行情况:
① please enter a,b,c:" 1,2,1 ↙
The equation has two equal roots,-1,0000
② please enter a,b,c:" 1,2,2↙
The equation has complex
-1,0000+ 1,
-1,0000- 1,0000i
③ please enter a,b,c:" 2,6,1↙
The equation has distinct real roots,-0.1771 and -2.8229
4.5 程序举例例 4.7 运输公司对用户计算运费。
路程(s)越远,每公里运费越低。标准如下:
s<250km 没有折扣
250 ≤s<500 2%折扣
500 ≤s<1000 5%折扣
1000 ≤s<2000 8%折扣
2000 ≤s<3000 10%折扣
3000 ≤s 15%折扣设每公里每吨货物的基本运费为p,货物重为w,
距离为s,折扣为d,则总运费f的计算公式为:
f=p *w *s *(1-d)
4.5 程序举例分析折扣变化的规律性:
折扣的,变化点,都是250的倍数在横轴上加一种坐标c,c的值为 s/250。
c代表 250的倍数。
c <1,无折扣;
1 ≤ c<2,折扣d=2%;
2 ≤ c<4,d=5%;
4 ≤ c<8,d=8%;
8 ≤ c<12,d=10%;
c ≥ 12,d=15%。
§ 4.5 程序举例(续)#include <stdio.h>void main ( )
{int c,s;
float p,w,d,f;
scanf("%f,%f,%d",&p,&w,&s);
if(s>=3000) c=12;
else c=s/250;
switch(c){
case 0:d=0;break;
case 1:d=2;break;
case 2:case 3:d=5;break;
case 4:case 5:case 6:case 7:d=8;break;
case 8:case 9:case 10:
case 11:d=10;break;
case 12:d=15;break; }
f=p*w*s*(1-d/100.0);
printf("freight=%15.4f\n",f);}
运行情况:
please enter price,weight,distance:23,345.7,136.45↙
freight=1081349.64