版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C語(yǔ)言程序設(shè)計(jì)主編:連衛(wèi)民 何 櫻第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)本章主要內(nèi)容:5.1 for 語(yǔ)句(重點(diǎn))5.2 while 語(yǔ)句(重點(diǎn))5.3 do-while 語(yǔ)句5.4 break 和 continue 語(yǔ)句5.5 多重循環(huán)(重點(diǎn))5.6 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)舉例本章教學(xué)要求:了解循環(huán)結(jié)構(gòu)的概念 熟悉循環(huán)結(jié)構(gòu)程序設(shè)計(jì)的方法 掌握while、do-while、for循環(huán)控制語(yǔ)句的使用方法。 5.1 for 語(yǔ)句本節(jié)主要介紹循環(huán)結(jié)構(gòu)的概念以及循環(huán)結(jié)構(gòu)程序能解決的問(wèn)題。 循環(huán)結(jié)構(gòu)的概念定義:循環(huán)是指在所設(shè)計(jì)的程序中,有條件地反復(fù)執(zhí)行某一段程序的現(xiàn)象。循環(huán)結(jié)構(gòu)是結(jié)構(gòu)化程序設(shè)計(jì)中一種很重要的結(jié)構(gòu),又稱為重復(fù)
2、結(jié)構(gòu)。循環(huán)的特點(diǎn):在給定條件成立時(shí),反復(fù)執(zhí)行某個(gè)程序段,直到條件不成立為止。給定的條件稱為循環(huán)條件,反復(fù)執(zhí)行的程序段稱為循環(huán)體。循環(huán)結(jié)構(gòu)的分類:當(dāng)型循環(huán)結(jié)構(gòu)和直到型循環(huán)結(jié)構(gòu)。 循環(huán)條件和循環(huán)體設(shè)置不好,很可能得不到預(yù)期的結(jié)果,甚至出現(xiàn)死循環(huán)。 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句5.1.1 for語(yǔ)句的格式for語(yǔ)句的一般格式為:for(表達(dá)式;表達(dá)式;表達(dá)式) 語(yǔ)句;其中:表達(dá)式1: 為循環(huán)變量賦初值表達(dá)式2: 為循環(huán)繼續(xù)的條件表達(dá)式3: 為循環(huán)變量的增值語(yǔ)句: 又被稱為循環(huán)體,它是當(dāng)表達(dá)式2為真(非0)時(shí)要重復(fù)執(zhí)行的語(yǔ)句,它可以由一條語(yǔ)句或復(fù)合語(yǔ)句組成。 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5
3、.1 for 語(yǔ)句5.1.2 for語(yǔ)句的執(zhí)行過(guò)程(1)計(jì)算表達(dá)式1的值,給循環(huán)變量賦初值,表達(dá)式僅在進(jìn)入for語(yǔ)句時(shí)執(zhí)行一次。(2)判斷表達(dá)式2的值,若其為“真”(非0),則執(zhí)行循環(huán)體語(yǔ)句,然后轉(zhuǎn)到第(3)步;若其為“假”(0),則結(jié)束循環(huán),執(zhí)行for語(yǔ)句的下一條語(yǔ)句。(3)計(jì)算表達(dá)式3的值。表達(dá)式3改變循環(huán)變量的值,它在每次執(zhí)行完循環(huán)體語(yǔ)句之后,都要被執(zhí)行一次。然后返回第(2)步繼續(xù)執(zhí)行。 for語(yǔ)句的執(zhí)行過(guò)程流程圖如圖5-1所示。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句說(shuō)明:(1)for語(yǔ)句的使用非常靈活,它的三個(gè)表達(dá)式可以省略1個(gè)或2個(gè),
4、也可以3個(gè)都省略,但間隔符“;”必須保留。例如:下列程序段把i=1提到for語(yǔ)句之前,省略了表達(dá)式1。 int i=1;s=0; for( ;i=100 ;i+) s=s+I;例如:下列兩個(gè)程序段均為死循環(huán),因?yàn)楸磉_(dá)式2的值永遠(yuǎn)為真。(2)在for語(yǔ)句中,表達(dá)式1和表達(dá)式3都可以是一項(xiàng)或是多項(xiàng),多于一項(xiàng)時(shí),各項(xiàng)之間用“,”分隔,形成逗號(hào)表達(dá)式。 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句5.1.3 for語(yǔ)句的用法【例5-1】編程計(jì)算s=1+2+3+.+100,用for語(yǔ)句實(shí)現(xiàn)。 依照此程序,請(qǐng)讀者自行完成下列編程題: 計(jì)算:s=1+3+5+.+99 計(jì)算:s=1+2+3+.+n第5章 循環(huán)
5、結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句【例5-2】編程求n!。分析:n!=1*2*3*n。求階乘時(shí)需要賦初值為1,不能是0,因?yàn)?乘任何數(shù)都是0如果n值較大,n!可能溢出,應(yīng)將結(jié)果變量說(shuō)明為float或double類型。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語(yǔ)句【例5-3】把100200之間能被7整除的數(shù)輸出。分析:能被7整除的數(shù)是:x%7=0#include int main() int i;for(i=100;i=200;i+) if(i%7=0) printf(%5d,i);printf(n);return 0;第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句5.2.1 while語(yǔ)句的格式w
6、hile語(yǔ)句的一般格式為: while(表達(dá)式) 語(yǔ)句;其中:(1)“表達(dá)式”是循環(huán)條件,可以為任何類型表達(dá)式,表達(dá)式必須用( )括起來(lái);(2)“語(yǔ)句”又被稱為循環(huán)體,為C語(yǔ)言中的任何一種語(yǔ)句(包括復(fù)合語(yǔ)句、if語(yǔ)句、case 語(yǔ)句)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句5.2.2 while語(yǔ)句的執(zhí)行過(guò)程while語(yǔ)句的執(zhí)行過(guò)程如下:(1)計(jì)算表達(dá)式的值,并判斷其為“真”(非0)或“假”(0)。(2)若表達(dá)式的值為“真”,則執(zhí)行循環(huán)體語(yǔ)句,然后返回到while語(yǔ)句重復(fù)第(1)步;若表達(dá)式的值為“假”,則結(jié)束循環(huán),執(zhí)行while語(yǔ)句的下一語(yǔ)句。while語(yǔ)句的執(zhí)行過(guò)程如圖5-2所示。
7、第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句說(shuō)明:(1)while語(yǔ)句的特點(diǎn)是:先判斷表達(dá)式,后執(zhí)行循環(huán)體語(yǔ)句。如果第一次判斷表達(dá)式的值為“假”,則循環(huán)體語(yǔ)句一次也不執(zhí)行。(2)循環(huán)體語(yǔ)句可以是一條語(yǔ)句,也可以是復(fù)合語(yǔ)句。(3)循環(huán)結(jié)構(gòu)由循環(huán)條件和循環(huán)體語(yǔ)句構(gòu)成,在循環(huán)體中應(yīng)該包含使循環(huán)趨向于結(jié)束的語(yǔ)句,否則會(huì)形成死循環(huán)。程序中應(yīng)避免出現(xiàn)死循環(huán)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句5.2.3 while語(yǔ)句的用法【例5-5】輸出一行數(shù)字0 1 2 3 4,要求每個(gè)數(shù)字中間空3格。#include int main()int i;i=0;while(i5) printf(%4d,i+
8、);printf(n);return 0; 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句【例5-6】將輸入的正文復(fù)制到輸出,每次一個(gè)字符。分析:以 E0F 為結(jié)束標(biāo)志的字符流稱為一個(gè)正文,可以包含空白字符,例如空格 和換行字符n。鍵入 Ctrl+z則 getchar 函數(shù)返回文件結(jié)束字符 EOF。程序中:c=getchar(); while(c!=EOF) putchar(c); c=getchar(); 可簡(jiǎn)化為:while(c=getchar()!=EOF) putchar(c);第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語(yǔ)句【例5-7】輸入一行字符,分別統(tǒng)計(jì)出其中英文字母、空格、數(shù)字的
9、個(gè)數(shù)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語(yǔ)句5.3.1 do-while語(yǔ)句的格式do-while語(yǔ)句的一般格式為:do 語(yǔ)句;while(表達(dá)式);其中:(1)語(yǔ)句部分可以是簡(jiǎn)單語(yǔ)句或復(fù)合語(yǔ)句;(2)表達(dá)式是循環(huán)條件,可以是任何類型表達(dá)式,表達(dá)式必須用()括起來(lái)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語(yǔ)句5.3.2 do-while語(yǔ)句的執(zhí)行過(guò)程do-while語(yǔ)句的執(zhí)行過(guò)程如下:(1)執(zhí)行循環(huán)體語(yǔ)句;(2)計(jì)算表達(dá)式的值,判斷其為“真”(非0)或“假”(0)。若為“真”,則返回第1步,繼續(xù)執(zhí)行循環(huán)體;若為“假”,則結(jié)束循環(huán),執(zhí)行do-while語(yǔ)句的下一語(yǔ)句。do-
10、while語(yǔ)句的執(zhí)行過(guò)程如圖5-3所示。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語(yǔ)句說(shuō)明:(1)do-while語(yǔ)句和while都能實(shí)現(xiàn)循環(huán)控制,while結(jié)構(gòu)的程序通常都可以轉(zhuǎn)換成do-while結(jié)構(gòu);(2)do-while語(yǔ)句與while語(yǔ)句的區(qū)別是:while語(yǔ)句先判斷循環(huán)條件是否滿足,如果滿足再執(zhí)行循環(huán)體,因此有可能一次也不執(zhí)行循環(huán)體;而do-while語(yǔ)句是先執(zhí)行一次循環(huán)體,然后再判斷循環(huán)條件是否滿足,因此,循環(huán)體至少要執(zhí)行一次。因此,do-while語(yǔ)句通常用于那些至少要執(zhí)行一次循環(huán)的情況。(3)do-while循環(huán)體中一定要有能使條件表達(dá)式值趨于0的操作,否則會(huì)出現(xiàn)死循環(huán)
11、。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語(yǔ)句5.3.3 do-while語(yǔ)句的用法【例5-9】計(jì)算: 直到最后一項(xiàng)的絕對(duì)值小于10-6為止。分析:這是一個(gè)求級(jí)數(shù)和問(wèn)題,方法是依次計(jì)算每一項(xiàng),并將該項(xiàng)與前面各項(xiàng)之和累加,如果某項(xiàng)絕對(duì)值小于10-6(反映精度),則求和結(jié)束,否則,重復(fù)上述過(guò)程。從式子的第二項(xiàng)起,每一項(xiàng)都是前一項(xiàng)乘以一個(gè)因子: (-x2)/(n*(n-1) (n=3,5,7,9,)如果用t表示每一項(xiàng)的值,則: t=t*(-x2)/(n*(n-1) (n=3,5,7,9,)第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語(yǔ)句5.3.4 三種循環(huán)語(yǔ)句比較 當(dāng)程序中需要用到循環(huán)語(yǔ)
12、句時(shí),選擇哪個(gè)語(yǔ)句和個(gè)人使用習(xí)慣有關(guān),但一般來(lái)說(shuō)有以下一些流行的風(fēng)格。(1)for語(yǔ)句適合循環(huán)次數(shù)已知的情況。(2)while語(yǔ)句適合循環(huán)次數(shù)不確定,但已知循環(huán)條件。(3)do-while語(yǔ)句與while語(yǔ)句可以互通使用,但do-while更適合于至少循環(huán)一次的情況。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語(yǔ)句5.4.1 break語(yǔ)句格式:break;功能:結(jié)束循環(huán),執(zhí)行循環(huán)語(yǔ)句的下一語(yǔ)句。break語(yǔ)句只能用于下面兩種情況:(1)出現(xiàn)在循環(huán)語(yǔ)句的循環(huán)體中,當(dāng)循環(huán)條件還未變?yōu)榧贂r(shí)提前結(jié)束循環(huán)語(yǔ)句的執(zhí)行(強(qiáng)行退出循環(huán))。(2)出現(xiàn)在switch語(yǔ)句中,使程序中途退出swit
13、ch語(yǔ)句,即跳過(guò)break語(yǔ)句之后直到switch語(yǔ)句體結(jié)束的所有語(yǔ)句。除上述兩處外,其他位置均不能出現(xiàn)break語(yǔ)句。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語(yǔ)句【例5-10】編寫程序,用循環(huán)計(jì)算圓面積,如果輸入非數(shù)字半徑則結(jié)束循環(huán)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語(yǔ)句5.4.2 continue語(yǔ)句格式:continue;功能:終止循環(huán)體的本次執(zhí)行,控制轉(zhuǎn)移到循環(huán)體的末尾,循環(huán)是否繼續(xù)取決于循環(huán)條件是否滿足。continue語(yǔ)句只能出現(xiàn)在循環(huán)語(yǔ)句的循環(huán)體中。例如:for(i=0;i10;i+) ch=getchar(); if(ch=n) c
14、ontinue; putchar(); 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.5 多重循環(huán)5.5.1 多重循環(huán)的格式多重循環(huán)的格式如下:while(表達(dá)式) for( 表達(dá)式1;表達(dá)式2;表達(dá)式3 ) 以上循環(huán)就構(gòu)成了雙重循環(huán)。三種循環(huán)語(yǔ)句(for、while、do-while)均可以互相嵌套形成多重循環(huán)結(jié)構(gòu)。需要注意,內(nèi)外層循環(huán)是完整的,相互之間不允許交叉。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.5 多重循環(huán)5.5.2 多重循環(huán)的執(zhí)行過(guò)程下面以一個(gè)雙重循環(huán)的程序?yàn)槔f(shuō)明多重循環(huán)的執(zhí)行過(guò)程?!纠?-11】寫出下列程序的運(yùn)行結(jié)果。 本例中:i 循環(huán)稱為外層循環(huán),控制輸出幾行j 循環(huán)稱為內(nèi)層循環(huán),控制一行輸出幾列第5
15、章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.5 多重循環(huán)5.5.3 多重循環(huán)的使用【例5-12】編程計(jì)算:s=1!+3!+5!第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.5 多重循環(huán)【例5-13】求Fibonacci數(shù)列:1,1,2,3,5,8, 的前40項(xiàng)。分析:Fibonacci的規(guī)律是:數(shù)列從第3項(xiàng)開始,每項(xiàng)都是其前兩項(xiàng)之和。即: a=1;b=1; a=a+b;b=a+b; a=a+b;b=a+b; 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.5 多重循環(huán)【例5-14】打印下列圖形: ABCDEF BCDEF CDEF DEF EF F第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.6 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)舉例【例5-15】任意10個(gè)數(shù),求正數(shù)的個(gè)數(shù)及正數(shù)和。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.6 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)舉例【例5-16】輸出三位數(shù)中的“水仙花數(shù)”。 水仙花數(shù)是指一個(gè)3位數(shù) ,其各位數(shù)字的 3次冪之和等于該數(shù)本身。例如,153是一個(gè)“水仙花數(shù)”,153=13+53+33分析:本題的關(guān)鍵是要分離出3位數(shù)的百位、十位和個(gè)位數(shù)字。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.6 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)舉例【例5-17】將一張100元的人民幣換成10元、5元和1元的零鈔,一共有幾種兌換方法。分析:因?yàn)?0元最多只能有2張,20元最多有5張,10元最多有10張,也可以一張也沒有,所以三個(gè)循環(huán)的范圍分別是:02、05、010第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.
溫馨提示
- 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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024老勞動(dòng)合同范本
- 2024新技術(shù)開發(fā)保密責(zé)任合同書版B版
- 2025年度公共場(chǎng)所消防安全管理合同細(xì)則3篇
- 2025年度數(shù)控車床采購(gòu)合同(含刀具智能檢測(cè)技術(shù))4篇
- 2025年度特殊人群客運(yùn)服務(wù)合同書-無(wú)障礙出行服務(wù)合作協(xié)議4篇
- 2025年度智慧醫(yī)療平臺(tái)建設(shè)出資擔(dān)保協(xié)議書4篇
- 2025年企業(yè)食堂承包及員工健康餐飲服務(wù)協(xié)議4篇
- 2024銷售人員提成獎(jiǎng)金分配勞動(dòng)合同3篇
- 2024蘋果期貨交易與風(fēng)險(xiǎn)管理合同3篇
- 2025年度抖音平臺(tái)虛擬商品交易安全保障協(xié)議3篇
- 第二章 運(yùn)營(yíng)管理戰(zhàn)略
- 《三本白皮書》全文內(nèi)容及應(yīng)知應(yīng)會(huì)知識(shí)點(diǎn)
- 專題14 思想方法專題:線段與角計(jì)算中的思想方法壓軸題四種模型全攻略(解析版)
- 醫(yī)院外來(lái)器械及植入物管理制度(4篇)
- 圖像識(shí)別領(lǐng)域自適應(yīng)技術(shù)-洞察分析
- 港口與港口工程概論
- 《念珠菌感染的治療》課件
- 個(gè)體戶店鋪?zhàn)赓U合同
- 門店裝修設(shè)計(jì)手冊(cè)
- 考研計(jì)算機(jī)學(xué)科專業(yè)基礎(chǔ)(408)研究生考試試卷與參考答案(2025年)
- 新概念英語(yǔ)第二冊(cè)考評(píng)試卷含答案(第49-56課)
評(píng)論
0/150
提交評(píng)論