第四講-分支選擇結(jié)構(gòu)程序設(shè)計(jì)2課件_第1頁(yè)
第四講-分支選擇結(jié)構(gòu)程序設(shè)計(jì)2課件_第2頁(yè)
第四講-分支選擇結(jié)構(gòu)程序設(shè)計(jì)2課件_第3頁(yè)
第四講-分支選擇結(jié)構(gòu)程序設(shè)計(jì)2課件_第4頁(yè)
第四講-分支選擇結(jié)構(gòu)程序設(shè)計(jì)2課件_第5頁(yè)
已閱讀5頁(yè),還剩39頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

2023/12/61復(fù)習(xí)關(guān)系運(yùn)算符if語(yǔ)句分支結(jié)構(gòu)程序設(shè)計(jì)思想2023/12/62邏輯判斷關(guān)系運(yùn)算符和關(guān)系表達(dá)式> 大于< 小于>= 大于等于<=小于等于== 等于!= 不等于2023/12/63關(guān)系判斷#include<stdio.h>main(){ intb,c; //整型變量 b=3;c=2; //對(duì)變量賦值 printf(“3>2是%d\n”,(b>c));//輸出邏輯值 printf(“3>=2是%d\n”,(b>=c)); printf(“3==2是%d\n”,(b==c)); printf(“3<2是%d\n”,(b<c)); printf(“3!=2是%d\n”,(b!=c));}2023/12/64

if(表達(dá)式)語(yǔ)句;

其語(yǔ)義是:如果表達(dá)式的值為真,則執(zhí)行其后的語(yǔ)句,否則不執(zhí)行該語(yǔ)句。如:

if(c<min)min=c;

單分支——選擇結(jié)構(gòu)的一種常用形式2023/12/65格式:if(條件)語(yǔ)句1;else語(yǔ)句2;

雙分支——選擇結(jié)構(gòu)的一種最常用形式工作過(guò)程圖

:條件2023/12/66本節(jié)內(nèi)容邏輯運(yùn)算符if語(yǔ)句應(yīng)用舉例switch語(yǔ)句及應(yīng)用2023/12/67雞兔同籠已知雞和兔的總數(shù)為n,總腿數(shù)為m。輸入n和m,依次輸出雞的數(shù)目和兔的數(shù)目,若無(wú)解,則輸出Noanswer!邏輯運(yùn)算符2023/12/68#include<stdio.h>main(){intchick,rabbit,n,m;scanf(“%d%d”,&n,&m);chick=(4*n-m)/2;rabbit=n-chick;

if(m%2==1||a<0||b<0)printf(“Noanswer!\n”);else

printf(“chicks:%d;rabbits:%d\n”,chick,rabbit);

}

必須保證chick和rabbit都是非負(fù)整數(shù)!2023/12/69分析:1、先根據(jù)輸入的三邊長(zhǎng),判斷能否構(gòu)成三角形,若能,則轉(zhuǎn)步驟2;若不能,則轉(zhuǎn)步驟3;2、使用海倫公式求三角形面積3、輸出提示:該三角形不存在。輸入三角形的三邊長(zhǎng),求三角形面積。2023/12/610#include<stdio.h>#include<math.h>main(){floata,b,c,s,area;scanf(“%f%f%f”,&a,&b,&c);

printf(“a=%7.2f,b=%7.2f,c=%7.2f\n”,a,b,c);s=(a+b+c)/2;area=sqrt(s*(s-a)*(s-b)*(s-c));printf(“area=%7.2f\n”,area);}if((a+b>c)&&(b+c>a)&&(a+c>b))elseprintf(“不能構(gòu)成三角形!\n”);2023/12/611邏輯運(yùn)算符與表達(dá)式關(guān)系表達(dá)式只能描述單一條件,例如“x>=0”。如果需要描述“x>=0”、同時(shí)“x<10”,就要借助于邏輯表達(dá)式了。

2023/12/6121、邏輯運(yùn)算符極其優(yōu)先次序C語(yǔ)言中提供了三種邏輯運(yùn)算符:&&與運(yùn)算||或運(yùn)算!非運(yùn)算邏輯運(yùn)算符與表達(dá)式2023/12/613邏輯與,運(yùn)算符為&&

如圖電路A——表示開(kāi)關(guān)A合上;B——表示開(kāi)關(guān)B合上;A&&B——表示燈亮;

A B A&&B

1 1 1

1 0 0

0 1 0

0 0 01表示真,0表示假,這是邏輯變量的取值,非真即假2023/12/614邏輯或,運(yùn)算符為||

如圖電路A——表示開(kāi)關(guān)A合上;B——表示開(kāi)關(guān)B合上;A||B——表示燈亮;

A B A||B

1 1 1

1 0 1

0 1 1

0 0 01表示真,0表示假邏輯非,運(yùn)算符為!兩隊(duì)比賽籃球,變量A表示A隊(duì)到場(chǎng),!A表示A隊(duì)不到場(chǎng),變量B表示B隊(duì)到場(chǎng),!B表示B隊(duì)不到場(chǎng)。這場(chǎng)球賽能夠賽成,必須兩隊(duì)都到場(chǎng)。假定“能賽成”用邏輯變量C表示,則

C=A&&B賽不成當(dāng)然用!C表示,讓D=!C,D表示賽不成則

D=!A||!B理解為A不到場(chǎng)或B不到場(chǎng),球賽均無(wú)法進(jìn)行。2023/12/616

!(非)(高)算術(shù)運(yùn)算符 關(guān)系運(yùn)算符 &&|| 賦值運(yùn)算符 (低)不使用邏輯運(yùn)算符可否判斷三邊長(zhǎng)構(gòu)成三角形?if(a+b>c)if(a+c>b)if(b+c>a){

s=(a+b+c)/2;area=sqrt(s*(s-a)*(s-b)*(s-c));}if的嵌套【例4-1】寫(xiě)一程序,從鍵盤(pán)上輸入某年份year(4位十進(jìn)制數(shù)),判斷其是否閏年。閏年的條件是:年份能被4整除、但不能被100整除;或者能被400整除。分析:1、從鍵盤(pán)輸入任意一年份,類型為十進(jìn)制整數(shù)2、判斷是否是閏年3、給出結(jié)論:“是”或“否”繼續(xù)對(duì)第2步進(jìn)行任務(wù)細(xì)化2.1、判斷該年份數(shù)字能否被4整除,并且不能被100整除若能,則是閏年,程序結(jié)束,否則進(jìn)入2.22.2、判斷該年份數(shù)字能否被400整除,若能,是閏年,程序結(jié)束,否則不是閏年,程序結(jié)束。程序優(yōu)化首先將是否閏年的標(biāo)志leap預(yù)置為0(非閏年),這樣僅當(dāng)year為閏年時(shí)將leap置為1即可。這種處理兩種狀態(tài)值的方法,對(duì)優(yōu)化算法和提高程序可讀性非常有效。利用邏輯運(yùn)算能描述復(fù)雜條件的特點(diǎn),使用邏輯運(yùn)算降低if語(yǔ)句的復(fù)雜性,使程序更簡(jiǎn)潔

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

………………else………………邏輯表達(dá)式的短路計(jì)算對(duì)于邏輯與運(yùn)算,例如“a&&b”,若a的邏輯值為“假”,則無(wú)須計(jì)算b的邏輯值,就可得知表達(dá)式“a&&b”的邏輯值為“假”。能被4整除,但是不能被100整除的年份是閏年

(k%4==0)&&(k%100!=0)對(duì)于邏輯或運(yùn)算,例如“a||b”,若a的邏輯值為“真”,則無(wú)須計(jì)算b的邏輯值,就可得知表達(dá)式“a||b”的邏輯值為“真”。因此,對(duì)于邏輯表達(dá)式,可以進(jìn)行短路計(jì)算,既只計(jì)算表達(dá)式的部分項(xiàng)。練習(xí)設(shè)a=3,b=4,c=5,試計(jì)算以下表達(dá)式的值a+b>c&&b==ca||b+c&&b–c(!(a+b)+c–1)&&(b+c/2)提出問(wèn)題:從鍵盤(pán)上輸入一個(gè)百分制成績(jī)score,按下列原則輸出其等級(jí):score≥90,等級(jí)為A;80≤score<90,等級(jí)為B;70≤score<80,等級(jí)為C;60≤score<70,等級(jí)為D;score<60,等級(jí)為E。若使用if語(yǔ)句如何編程解決?二、switch語(yǔ)句

C語(yǔ)言還提供了另一種用于多分支選擇的switch語(yǔ)句,其一般形式為:

switch(表達(dá)式){

case常量表達(dá)式1:語(yǔ)句1;

case常量表達(dá)式2:語(yǔ)句2;…

case常量表達(dá)式n:語(yǔ)句n;

[default:語(yǔ)句n+1;]}[例4.2]main(){inta;printf("inputintegernumber:");scanf("%d",&a);switch(a){ case1:printf(“Monday\n”); case2:printf("Tuesday\n"); case3:printf("Wednesday\n"); case4:printf("Thursday\n"); case5:printf("Friday\n"); case6:printf("Saturday\n"); case7:printf("Sunday\n"); default:printf("error\n");}}swich語(yǔ)句的語(yǔ)義是:計(jì)算switch后的括號(hào)內(nèi)的表達(dá)式的值;逐個(gè)與case后的常量表達(dá)式值相比較,

當(dāng)表達(dá)式的值與某個(gè)case后的常量表達(dá)式的值相等時(shí),即執(zhí)行其后的語(yǔ)句,然后不再進(jìn)行與case后常量表達(dá)式的比較,繼續(xù)執(zhí)行后面所有case常量表達(dá)式:后的語(yǔ)句。若表達(dá)式的值與所有case后的常量表達(dá)式均不相同時(shí),則執(zhí)行default后的語(yǔ)句。main(){inta;printf("inputintegernumber:");scanf("%d",&a);switch(a){ case1:printf(“Monday\n”);break; case2:printf("Tuesday\n");break; case3:printf("Wednesday\n");break; case4:printf("Thursday\n");break; case5:printf("Friday\n");break; case6:printf("Saturday\n");break; case7:printf("Sunday\n");break; default:printf("error\n");}}[例4.3]從鍵盤(pán)上輸入一個(gè)百分制成績(jī)score,按下列原則輸出其等級(jí):score≥90,等級(jí)為A;80≤score<90,等級(jí)為B;70≤score<80,等級(jí)為C;60≤score<70,等級(jí)為D;score<60,等級(jí)為E。

main()

{intscore,grade;

printf(“Inputascore(0~100):”);

scanf(“%d”,&score);

grade=score/10;//將成績(jī)整除10,轉(zhuǎn)化成switch語(yǔ)句中的case標(biāo)號(hào)switch(grade){case10:case9:printf(“grade=A\n”);breakcase8:printf("grade=B\n");break;case7:printf("grade=C\n");break;case6:printf("grade=D\n");break;case5:case4:case3:case2:case1:case0:printf(“grade=E\n”);break;default:printf(“Thescoreisoutofrange!\n”); }

}

例4-4已知某公司員工的保底薪水為500,某月所接工程的利潤(rùn)profit(整數(shù))與利潤(rùn)提成的關(guān)系如下(計(jì)量單位:元):

profit≤1000 沒(méi)有提成;1000<profit

≤2000 提成10%;2000<profit≤5000 提成15%;5000<profit≤10000 提成20%;10000<profit 提成25%。為使用switch語(yǔ)句,必須將利潤(rùn)profit與提成的關(guān)系,轉(zhuǎn)換成某些整數(shù)與提成的關(guān)系。分析本題可知,提成的變化點(diǎn)都是1000的整數(shù)倍(1000、2000、5000、100000)如果將利潤(rùn)profit整除1000,則當(dāng):

profit≤1000 對(duì)應(yīng)0、11000<profit≤2000 對(duì)應(yīng)1、22000<profit≤5000 對(duì)應(yīng)2、3、4、55000<profit≤10000 對(duì)應(yīng)5、6、7、8、9、1010000<profit 對(duì)應(yīng)10、11、12、……為解決相鄰兩個(gè)區(qū)間的重疊問(wèn)題,最簡(jiǎn)單的方法就是:利潤(rùn)profit先減1(最小增量),然后再整除1000即可:

profit≤1000 對(duì)應(yīng)01000<profit≤2000 對(duì)應(yīng)12000<profit≤5000 對(duì)應(yīng)2、3、45000<profit≤10000 對(duì)應(yīng)5、6、7、8、910000<profit 對(duì)應(yīng)10、11、12、……main(){longprofit;intgrade;floatcommission,salary=500;printf("Inputprofit:");scanf("%ld",&profit);

grade=(profit–1)/1000;switch(grade){case0:commission=0;break; /*profit≤1000*/case1:commission=profit*0.1;break; /*1000<profit≤2000*/case2:case3:case4:commission=profit*0.15;break; /*2000<profit≤5000*/case5:case6:case7:case8:case9:commission=profit*0.2;break; /*5000<profit≤10000*/default:commission=profit*0.25; /*10000<profit*/}salary+=commission;printf("salary=%.2f\n",salary);}2023/12/632三整數(shù)排序輸入3個(gè)整數(shù),從小到大排序后輸出。樣例:輸入20733

輸出72033if語(yǔ)句應(yīng)用實(shí)例2023/12/633三整數(shù)排序分析

a,b,c三個(gè)數(shù)共有6種由大到小排序可能我們用6條if語(yǔ)句實(shí)現(xiàn)排序如何?2023/12/634三整數(shù)排序

if(a<b&&b<c) printf("%d,%d,%d\n",a,b,c); if(a<c&&c<b) printf("%d,%d,%d\n",a,c,b); if(b<a&&a<c) printf("%d,%d,%d\n",b,a,c); if(b<c&&c<a) printf("%d,%d,%d\n",b,c,a); if(c<a&&a<b) printf("%d,%d,%d\n",c,a,b); if(c<b&&b<a) printf("%d,%d,%d\n",c,b,a);存在問(wèn)題嗎?2023/12/635三整數(shù)排序if(a<=b&&b<=c) printf("%d,%d,%d\n",a,b,c); if(a<=c&&c<=b) printf("%d,%d,%d\n",a,c,b); if(b<=a&&a<=c) printf("%d,%d,%d\n",b,a,c); if(b<=c&&c<=a) printf("%d,%d,%d\n",b,c,a); if(c<=a&&a<=b) printf("%d,%d,%d\n",c,a,b); if(c<=b&&b<=a) printf("%d,%d,%d\n",c,b,a);存在問(wèn)題嗎?2023/12/636三整數(shù)排序 if(a<=b&&b<=c) printf("%d,%d,%d\n",a,b,c); else if(a<=c&&c<=b) printf("%d,%d,%d\n",a,c,b); else if(b<=a&&a<=c)printf("%d,%d,%d\n",b,a,c); elseif(b<=c&&c<=a)printf("%d,%d,%d\n",b,c,a); else if(c<=a&&a<=b)printf("%d,%d,%d\n",c,a,b); else if(c<=b&&b<=a)printf("%d,%d,%d\n",c,b,a);2023/12/637三整數(shù)排序

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("%d,%d,%d\n",a,b,c);復(fù)合語(yǔ)句2023/12/638三整數(shù)排序min=a; if(b<min)

min=b;

if(c<min)

min=c;

max=a; if(b>max)max=b; if(c>max)max=c;

mid=a+b+c-min-max; printf("%d,%d,%d\n",min,mid,max);很有用的技巧哦:求最大值或最小值在使用if語(yǔ)句中應(yīng)注意的問(wèn)題:在各種形式的if語(yǔ)句中,在if關(guān)鍵字之后均為表達(dá)式。該表達(dá)式通常是邏輯表達(dá)式或關(guān)系表達(dá)式,但也可以是其它任意合法表達(dá)式,如賦值表達(dá)式等,甚至也可以是一個(gè)變量。例如:

if(a=5)語(yǔ)句;if(b)語(yǔ)句;在C中,將非零數(shù)認(rèn)定為“真”,零認(rèn)定為“假”。

在if語(yǔ)句中,if后的表達(dá)式必須用括號(hào)括起來(lái),在語(yǔ)句之后必須加分號(hào)。在if語(yǔ)句的各種形式中,所有的語(yǔ)句應(yīng)為單個(gè)語(yǔ)句,如果要想在滿足條件時(shí)執(zhí)行一組(多個(gè))語(yǔ)句,則必須把這一組語(yǔ)句用{}括起來(lái)組成一個(gè)復(fù)合語(yǔ)句;但要注意的是在}之后不能再加分號(hào)。例如:if(a>b){a++;b++;}else{a=0;b=10;}

下次上機(jī)題目編程,在輸入某人的身高(厘米)和體重(公斤)后

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論