版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C語言程序設(shè)計(jì)主編:連衛(wèi)民 何 櫻第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)本章主要內(nèi)容:5.1 for 語句(重點(diǎn))5.2 while 語句(重點(diǎn))5.3 do-while 語句5.4 break 和 continue 語句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)控制語句的使用方法。 5.1 for 語句本節(jié)主要介紹循環(huán)結(jié)構(gòu)的概念以及循環(huán)結(jié)構(gòu)程序能解決的問題。 循環(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 語句5.1.1 for語句的格式for語句的一般格式為:for(表達(dá)式;表達(dá)式;表達(dá)式) 語句;其中:表達(dá)式1: 為循環(huán)變量賦初值表達(dá)式2: 為循環(huán)繼續(xù)的條件表達(dá)式3: 為循環(huán)變量的增值語句: 又被稱為循環(huán)體,它是當(dāng)表達(dá)式2為真(非0)時(shí)要重復(fù)執(zhí)行的語句,它可以由一條語句或復(fù)合語句組成。 第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5
3、.1 for 語句5.1.2 for語句的執(zhí)行過程(1)計(jì)算表達(dá)式1的值,給循環(huán)變量賦初值,表達(dá)式僅在進(jìn)入for語句時(shí)執(zhí)行一次。(2)判斷表達(dá)式2的值,若其為“真”(非0),則執(zhí)行循環(huán)體語句,然后轉(zhuǎn)到第(3)步;若其為“假”(0),則結(jié)束循環(huán),執(zhí)行for語句的下一條語句。(3)計(jì)算表達(dá)式3的值。表達(dá)式3改變循環(huán)變量的值,它在每次執(zhí)行完循環(huán)體語句之后,都要被執(zhí)行一次。然后返回第(2)步繼續(xù)執(zhí)行。 for語句的執(zhí)行過程流程圖如圖5-1所示。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語句第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語句說明:(1)for語句的使用非常靈活,它的三個(gè)表達(dá)式可以省略1個(gè)或2個(gè),
4、也可以3個(gè)都省略,但間隔符“;”必須保留。例如:下列程序段把i=1提到for語句之前,省略了表達(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語句中,表達(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 語句5.1.3 for語句的用法【例5-1】編程計(jì)算s=1+2+3+.+100,用for語句實(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 語句【例5-2】編程求n!。分析:n!=1*2*3*n。求階乘時(shí)需要賦初值為1,不能是0,因?yàn)?乘任何數(shù)都是0如果n值較大,n!可能溢出,應(yīng)將結(jié)果變量說明為float或double類型。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.1 for 語句【例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語句5.2.1 while語句的格式w
6、hile語句的一般格式為: while(表達(dá)式) 語句;其中:(1)“表達(dá)式”是循環(huán)條件,可以為任何類型表達(dá)式,表達(dá)式必須用( )括起來;(2)“語句”又被稱為循環(huán)體,為C語言中的任何一種語句(包括復(fù)合語句、if語句、case 語句)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語句5.2.2 while語句的執(zhí)行過程while語句的執(zhí)行過程如下:(1)計(jì)算表達(dá)式的值,并判斷其為“真”(非0)或“假”(0)。(2)若表達(dá)式的值為“真”,則執(zhí)行循環(huán)體語句,然后返回到while語句重復(fù)第(1)步;若表達(dá)式的值為“假”,則結(jié)束循環(huán),執(zhí)行while語句的下一語句。while語句的執(zhí)行過程如圖5-2所示。
7、第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語句說明:(1)while語句的特點(diǎn)是:先判斷表達(dá)式,后執(zhí)行循環(huán)體語句。如果第一次判斷表達(dá)式的值為“假”,則循環(huán)體語句一次也不執(zhí)行。(2)循環(huán)體語句可以是一條語句,也可以是復(fù)合語句。(3)循環(huán)結(jié)構(gòu)由循環(huán)條件和循環(huán)體語句構(gòu)成,在循環(huán)體中應(yīng)該包含使循環(huán)趨向于結(jié)束的語句,否則會(huì)形成死循環(huán)。程序中應(yīng)避免出現(xiàn)死循環(huán)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.2 while語句5.2.3 while語句的用法【例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語句【例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語句【例5-7】輸入一行字符,分別統(tǒng)計(jì)出其中英文字母、空格、數(shù)字的
9、個(gè)數(shù)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語句5.3.1 do-while語句的格式do-while語句的一般格式為:do 語句;while(表達(dá)式);其中:(1)語句部分可以是簡(jiǎn)單語句或復(fù)合語句;(2)表達(dá)式是循環(huán)條件,可以是任何類型表達(dá)式,表達(dá)式必須用()括起來。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語句5.3.2 do-while語句的執(zhí)行過程do-while語句的執(zhí)行過程如下:(1)執(zhí)行循環(huán)體語句;(2)計(jì)算表達(dá)式的值,判斷其為“真”(非0)或“假”(0)。若為“真”,則返回第1步,繼續(xù)執(zhí)行循環(huán)體;若為“假”,則結(jié)束循環(huán),執(zhí)行do-while語句的下一語句。do-
10、while語句的執(zhí)行過程如圖5-3所示。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.3 do-while語句說明:(1)do-while語句和while都能實(shí)現(xiàn)循環(huán)控制,while結(jié)構(gòu)的程序通常都可以轉(zhuǎn)換成do-while結(jié)構(gòu);(2)do-while語句與while語句的區(qū)別是:while語句先判斷循環(huán)條件是否滿足,如果滿足再執(zhí)行循環(huán)體,因此有可能一次也不執(zhí)行循環(huán)體;而do-while語句是先執(zhí)行一次循環(huán)體,然后再判斷循環(huán)條件是否滿足,因此,循環(huán)體至少要執(zhí)行一次。因此,do-while語句通常用于那些至少要執(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語句5.3.3 do-while語句的用法【例5-9】計(jì)算: 直到最后一項(xiàng)的絕對(duì)值小于10-6為止。分析:這是一個(gè)求級(jí)數(shù)和問題,方法是依次計(jì)算每一項(xiàng),并將該項(xiàng)與前面各項(xiàng)之和累加,如果某項(xiàng)絕對(duì)值小于10-6(反映精度),則求和結(jié)束,否則,重復(fù)上述過程。從式子的第二項(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語句5.3.4 三種循環(huán)語句比較 當(dāng)程序中需要用到循環(huán)語
12、句時(shí),選擇哪個(gè)語句和個(gè)人使用習(xí)慣有關(guān),但一般來說有以下一些流行的風(fēng)格。(1)for語句適合循環(huán)次數(shù)已知的情況。(2)while語句適合循環(huán)次數(shù)不確定,但已知循環(huán)條件。(3)do-while語句與while語句可以互通使用,但do-while更適合于至少循環(huán)一次的情況。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語句5.4.1 break語句格式:break;功能:結(jié)束循環(huán),執(zhí)行循環(huán)語句的下一語句。break語句只能用于下面兩種情況:(1)出現(xiàn)在循環(huán)語句的循環(huán)體中,當(dāng)循環(huán)條件還未變?yōu)榧贂r(shí)提前結(jié)束循環(huán)語句的執(zhí)行(強(qiáng)行退出循環(huán))。(2)出現(xiàn)在switch語句中,使程序中途退出swit
13、ch語句,即跳過break語句之后直到switch語句體結(jié)束的所有語句。除上述兩處外,其他位置均不能出現(xiàn)break語句。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語句【例5-10】編寫程序,用循環(huán)計(jì)算圓面積,如果輸入非數(shù)字半徑則結(jié)束循環(huán)。第5章 循環(huán)結(jié)構(gòu)程序設(shè)計(jì)5.4 break和continue語句5.4.2 continue語句格式:continue;功能:終止循環(huán)體的本次執(zhí)行,控制轉(zhuǎn)移到循環(huán)體的末尾,循環(huán)是否繼續(xù)取決于循環(huán)條件是否滿足。continue語句只能出現(xiàn)在循環(huán)語句的循環(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)語句(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í)行過程下面以一個(gè)雙重循環(huán)的程序?yàn)槔?,說明多重循環(huán)的執(zhí)行過程。【例5-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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023三年級(jí)語文上冊(cè) 第三單元 9 那一定會(huì)很好配套教學(xué)實(shí)錄 新人教版
- 建筑論文調(diào)研報(bào)告范文
- 建行個(gè)人研修報(bào)告范文
- 企業(yè)員工管理制度集粹大合集
- 2024年中國密度板家具市場(chǎng)調(diào)查研究報(bào)告
- 第5單元 16夏天里的成長(zhǎng)(教學(xué)實(shí)錄)2024-2025學(xué)年六年級(jí)語文上冊(cè)同步教學(xué)(統(tǒng)編版)
- 廣東省深圳市龍華區(qū)2023-2024學(xué)年八年級(jí)下學(xué)期物理期末試題+
- 2024年秋季小學(xué)數(shù)學(xué)北京課改版五年級(jí)【數(shù)學(xué)(北京版)】小數(shù)除法解決問題(第二課時(shí))-1教學(xué)設(shè)計(jì)
- 機(jī)械設(shè)計(jì)基礎(chǔ)課件 模塊3 平面連桿機(jī)構(gòu)分析與設(shè)計(jì)
- 微機(jī)課程設(shè)計(jì)8253
- 2022-2023學(xué)年廣東省廣州市增城區(qū)九年級(jí)(上)期末數(shù)學(xué)試卷(含解析)
- 心理咨詢與治療學(xué)智慧樹知到期末考試答案章節(jié)答案2024年南方醫(yī)科大學(xué)
- 2024年輔警招聘考試試題庫及完整答案(全優(yōu))
- 抖音等短視頻mcn機(jī)構(gòu)組建與運(yùn)營商業(yè)計(jì)劃書
- 護(hù)理方案優(yōu)化總結(jié)分析報(bào)告
- 美國史智慧樹知到期末考試答案2024年
- 二年級(jí)體育教師工作述職報(bào)告
- 2024年1月電大國家開放大學(xué)期末試題及答案:物流信息系統(tǒng)管理
- 【川教版】《生命 生態(tài) 安全》五上第8課《防患于未“燃”》課件
- 家庭責(zé)任醫(yī)生團(tuán)隊(duì)長(zhǎng)競(jìng)聘專項(xiàng)方案
- 卓有成效的管理者pdf
評(píng)論
0/150
提交評(píng)論