C語言第5章循環(huán)結(jié)構(gòu)_第1頁
C語言第5章循環(huán)結(jié)構(gòu)_第2頁
C語言第5章循環(huán)結(jié)構(gòu)_第3頁
C語言第5章循環(huán)結(jié)構(gòu)_第4頁
C語言第5章循環(huán)結(jié)構(gòu)_第5頁
已閱讀5頁,還剩49頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第5章循環(huán)結(jié)構(gòu)問題的提出:對于這樣的一類問題:問題1.從鍵盤輸入100個(gè)學(xué)生的成績,求總成績。問題2.求100以內(nèi)的素?cái)?shù)問題3.求1!+2!+3!+…+10!用前面所學(xué)知識來解決這些問題是非常麻煩的對于問題1的一個(gè)笨辦法:設(shè)一個(gè)變量,每次輸入一個(gè)學(xué)生成績,累加后再輸入下一個(gè)學(xué)生成績,如下:

scanf(“%f”,&a);s=s+a;

scanf(“%f”,&a);s=s+a;………….

這樣重復(fù)100次,然后輸出s的值。是否可用一種語句,使這兩句話能自動的重復(fù)執(zhí)行100次,以簡化書寫的麻煩呢?這就是循環(huán)語句的任務(wù)。5.1goto循環(huán)結(jié)構(gòu)概述C語言可實(shí)現(xiàn)循環(huán)的語句:用goto

和if構(gòu)成循環(huán)while語句do~while語句for語句goto語句及用goto構(gòu)成循環(huán)goto語句一般格式:

goto

語句標(biāo)號;

….…..標(biāo)號:語句;

功能:無條件轉(zhuǎn)移語句說明:不能用整數(shù)作標(biāo)號只能出現(xiàn)在goto所在函數(shù)內(nèi),且唯一只能加在可執(zhí)行語句前面限制使用goto語句sum=0+1sum=1+2=3sum=3+3=6sum=6+4……sum=4950+100=5050例用if和goto語句構(gòu)成循環(huán),求#include<stdio.h>main(){int

i,sum=0;i=1;loop:if(i<=100){sum=sum+i; i++;

gotoloop;}

printf("%d",sum);}循環(huán)初值終循環(huán)值循環(huán)變量增值循環(huán)條件循環(huán)體例用if和goto語句構(gòu)成循環(huán),求5.2while循環(huán)結(jié)構(gòu)一般形式:while(表達(dá)式)

循環(huán)體語句;執(zhí)行流程:expr循環(huán)體假(0)真(非0)while特點(diǎn):先判斷表達(dá)式,后執(zhí)行循環(huán)體說明:循環(huán)體有可能一次也不執(zhí)行循環(huán)體可為任意類型語句下列情況,退出while循環(huán)條件表達(dá)式不成立(為零)循環(huán)體內(nèi)遇break,return,goto無限循環(huán):while(1)

循環(huán)體;例用while循環(huán)求

/*ch5_2.c*/#include<stdio.h>main(){inti,sum=0;i=101;while(i<=100){sum=sum+i;i++;}

printf("%d",sum);}循環(huán)初值循環(huán)終值循環(huán)變量增值循環(huán)條件循環(huán)體應(yīng)注意:1、計(jì)數(shù)器和累加器的初值;2、一次循環(huán)后,循環(huán)控制變量的變化情況。3、跳出循環(huán)時(shí)循環(huán)控制變量的值應(yīng)為多少?例顯示1~10的平方/*ch5_21.c*/#include<stdio.h>main(){inti=1;while(i<=10){printf("%d*%d=%d\n",i,i,i*i);i++;}}運(yùn)行結(jié)果:1*1=12*2=43*3=94*4=165*5=256*6=367*7=498*8=649*9=8110*10=100注意:循環(huán)控制變量值在循環(huán)體內(nèi)必須有所改變。

例如:請問下例中循環(huán)結(jié)束時(shí)i值為多少?i=1;while(i<=100)

putchar(‘*’);i++;這個(gè)循環(huán)永遠(yuǎn)不會結(jié)束,因?yàn)檠h(huán)控制變量i沒有在循環(huán)體內(nèi)被改變,i++;不屬于循環(huán)語句。i++應(yīng)該在循環(huán)體內(nèi)改變:{}do

循環(huán)體語句;

while(表達(dá)式);執(zhí)行流程:do循環(huán)體expr假(0)真(非0)while5.3do…while循環(huán)結(jié)構(gòu)一般形式:特點(diǎn):先執(zhí)行循環(huán)體,后判斷表達(dá)式說明:至少執(zhí)行一次循環(huán)體do~while可轉(zhuǎn)化成while結(jié)構(gòu)expr循環(huán)體假(0)真(非0)循環(huán)體While循環(huán)例用do~while循環(huán)求

#include<stdio.h>main(){inti,sum=0;i=1;do{sum+=i; i++;}while(i<=100);

printf("%d",sum);}例while和do~while比較/*ch5_4.c*/#include<stdio.h>main(){inti,sum=0;

scanf("%d",&i);do{sum+=i; i++;}while(i<=10);

printf("%d",sum);}main(){inti,sum=0;

scanf("%d",&i);while(i<=10){sum+=i; i++;}

printf("%d",sum);}1、跳出循環(huán)時(shí)循環(huán)控制變量的值應(yīng)為多少?如果輸入值為1,10,20時(shí)呢?2、輸出結(jié)果呢?1.while結(jié)構(gòu)與do-while循環(huán)結(jié)構(gòu)相類似.2.但要注意區(qū)別:前者:先判斷表達(dá)式,再執(zhí)行語句。至少要執(zhí)行0次后者:先執(zhí)行語句,再判斷表達(dá)式。至少要執(zhí)行1次。3.也就是說用兩種循環(huán)結(jié)構(gòu)處理同一問題時(shí),若二者的循環(huán)體部分是一樣的,當(dāng)while后面表達(dá)式的第一次的值為“真(非0)”時(shí),兩種循環(huán)結(jié)構(gòu)得到的結(jié)果相同,否則二者的結(jié)果不相同。While與do–while循環(huán)結(jié)構(gòu)的比較一般形式:for(循環(huán)變量賦初值;循環(huán)條件;循環(huán)變量增(減)值){

循環(huán)體語句;}for(expr1;expr2;expr3){

循環(huán)體語句;}5.4for循環(huán)結(jié)構(gòu)執(zhí)行流程:循環(huán)條件循環(huán)體假(0)真(非0)for賦初值循環(huán)變量增(減)值例用for循環(huán)求

#include<stdio.h>main(){inti,sum=0;for(i=1;i<=100;i++)sum+=i;

printf("%d",sum);}說明:for語句中expr1,expr2,expr3類型任意,都可省略,但分號;不可省無限循環(huán):for(;;)for語句可以轉(zhuǎn)換成while結(jié)構(gòu)expr1;while(expr2){

循環(huán)體語句;

expr3;}例:#include<stdio.h>main(){inti=0;for(i=0;i<10;i++)

putchar(‘a(chǎn)’+i);}輸出結(jié)果:abcdefghij例:#include<stdio.h>main(){inti=0;for(;i<10;i++)

putchar(‘a(chǎn)’+i);}例:#include<stdio.h>main(){inti=0;for(;i<10;)

putchar(‘a(chǎn)’+(i++));}例:#include<stdio.h>main(){inti=0;for(;i<10;putchar(‘a(chǎn)’+i),i++);}逗號表達(dá)式

逗號運(yùn)算符的主要應(yīng)用就在for語句中。for語句中的表達(dá)式1和表達(dá)式3可以是逗號表達(dá)式,特別是有兩個(gè)循環(huán)變量參與對循環(huán)的控制時(shí)。表達(dá)式1和表達(dá)式3為逗號表達(dá)式,將使程序顯得非常清晰。main(){int

i,j,k=0;

for(i=1,j=100;i<j;i++,j--)k=k+i+j;

printf("%d\n",k);}

5.5輔助控制語句break語句功能:在循環(huán)語句和switch語句中,終止并跳出循環(huán)體或開關(guān)體說明:break只能終止并跳出最近一層的結(jié)構(gòu)break不能用于循環(huán)語句和switch語句之外的任何其它語句之中例break舉例:輸出圓面積,面積大于100時(shí)停止main(){

intr;floatarea;for(r=1;r<=10;r++){area=3.14159*r*r;if(area>100) break;

printf("r=%d,area=%.2f\n",r,area);}}例小寫字母轉(zhuǎn)換成大寫字母,直至輸入非字母字符#include<stdio.h>main(){

inti,j;charc;while(1){c=getchar(); if(c>='a'&&c<='z')

putchar(c-'a'+'A'); else break;}}例判斷m是否素?cái)?shù)讀入mk=mi=2當(dāng)ikm被i整除真假用break結(jié)束循環(huán)i=i+1ik+1真假輸出:m”是素?cái)?shù)”輸出:m”不是素?cái)?shù)”#include<stdio.h>#include<math.h>main(){int

m,i,k;

scanf("%d",&m);k=sqrt(m);

for(i=2;i<=k;i++)

if(m%i==0)break;

if(i>=k+1)

printf("%disaprimenumber\n",m);else

printf("%disnotaprimenumber\n",m);}continue語句功能:結(jié)束本次循環(huán),跳過循環(huán)體中尚未執(zhí)行的語句,進(jìn)行下一次是否執(zhí)行循環(huán)體的判斷僅用于循環(huán)語句中例求輸入的十個(gè)整數(shù)中正數(shù)的個(gè)數(shù)及其平均值#include<stdio.h>main(){inti,num=0,a;floatsum=0;for(i=0;i<10;i++){scanf("%d",&a); if(a<=0)continue; num++; sum+=a;}

printf("%d

,%f\n",num,sum);

printf("Meanvalue:%f\n",sum/num);}【源程序】main(){intn=1;n

while(n<=10){if(n==6)continue;printf("%4d",n);n++;}}請問:

跳出循環(huán)時(shí)循環(huán)控制變量的值應(yīng)為多少?運(yùn)行結(jié)果呢?該程序有何問題?如果有該如何改正?無限循環(huán);運(yùn)行結(jié)果:12345例.閱讀程序并回答問題5.6第4-5章實(shí)例解析4輸入三個(gè)實(shí)數(shù),判斷是否能構(gòu)成三角形,如能,說明是何種三角形,等邊,等腰,直角

#include<stdio.h>main(){doubled,x,y,z;

scanf("%lf,%lf,%lf",&x,&y,&z);if(x+y<=z||z+y<=x||x+z<=y||x<=0||y<=0||z<=0)

printf(“不能構(gòu)成三角形”);

else{if(x==y&&y==z)

printf(“構(gòu)成等邊三角形”);

if(x==y||y==z||x==z)

printf(“構(gòu)成等腰三角形”);if((x*x+y*y==z*z)||(x*x==y*y+z*z)||(x*x+z*z==y*y))

printf(“構(gòu)成直角三角形”);}}#include<stdio.h>#include<math.h>main(){floata,b,c,m,n,x1,x2;

scanf("%f%f%f",&a,&b,&c);n=-b/(2*a);m=b*b-4*a*c;

if(m==0){x1=x2=n;printf("x1=x2=%f\n",x1);}else

if(m>0){x1=n+sqrt(m)/(2*a);x1=n-sqrt(m)/(2*a);

printf("x1=%f,x2=%f\n",x1,x2);}

else

{x1=n;x2=sqrt(fabs(m))/(2*a);

printf("x1=%f+%fi,x2=%f-%fi\n",x1,x2,x1,x2);}}輸入:a=1,b=3,c=2輸出:x1=-1.00x2=-2.00循環(huán)舉例:1.顯示輸入的字符,如果按的是Esc鍵,則退出循環(huán);如果按的是Enter鍵,則不做任何處理,繼續(xù)輸入下一個(gè)字符。#include“conio.h”main(){ charch;

for(;;){ ch=getch();/*不帶回顯的字符輸入函數(shù)*/

if(ch==27)/*Esc鍵的ACSII碼為27*/break;/*退出循環(huán)*/if(ch==13)continue;/*按的是Enter:鍵,跳過字符輸出語句*/

putch(ch);/*顯示輸入的字符*/}}main(){

intn;longt=1,sum=0;//注意累乘器及累加器的初值

for(n=1;n<100;n++){t=t*n;if(n%2==0)continue;sum=sum+t;}

printf("sum=%ld\n",sum);}次數(shù)123…9899t1!2!3!…98!99!sum1!-+3!-+99!n234…99100每次循環(huán)后,重要變量的變化情況【例】計(jì)算1!+3!+5!+…+99!。分析:該題實(shí)質(zhì)上是一個(gè)累加求和的問題,而且已知其循環(huán)的次數(shù)因此可以用for語句來實(shí)現(xiàn);對于累加應(yīng)有選擇地進(jìn)行,即只對奇數(shù)項(xiàng)求和,可以用if語句和continue語句組合來進(jìn)行選擇性地累加。例:求1/99+2/98+…+1main(){floats=0.0;int

i,j;

for(i=1,j=99;i<=j;i++,j--)s=s+(float)i/j;

printf(“result

is:%f”,s);}次數(shù)1234…484950i2345…495051j98979695…515049main(){inti=1,n;floatt,x=1,y=2,m,sum=0;

while(i<=30){m=y/x;sum=sum+m;t=y;y=y+x;x=t;i++;}

printf(“\n%ld”,sum);}例.P772/1,3/2,5/3,8/5,/21/13….求該數(shù)列的前30項(xiàng)之和例求Fibonacci數(shù)列:1,1,2,3,5,8,……的前40個(gè)數(shù)1534233159710946750255142293524578241578171855377258417711121393832040570288739088169213896104181286571964181346269922746563245986321144987676546368317811217830914930352102334155

main(){longintf1,f2;

inti;f1=1;f2=1;for(i=1;i<20;i++){printf(“%12ld%12ld”,f1,f2);if(i%2==0)printf(“\n”);f1=f1+f2;f2=f2+f1;}

}循環(huán)嵌套舉例循環(huán)嵌套舉例問題:輸出圖形**********分析:一共4行,每行的‘*’數(shù)目與行號相同算法:行用i表示,

當(dāng)i<=4do{輸出i個(gè)‘*’換行

}Main(){inti,j;for(i=1;i<5;i++){printf("\n");for(j=1;j<=i;j++)

putchar('*');}}打印3至1000之間的全部素?cái)?shù),并求所有素?cái)?shù)的個(gè)數(shù)。例判斷m是否素?cái)?shù)讀入mk=mi=2當(dāng)ikm被i整除真假用break結(jié)束循環(huán)i=i+1ik+1真假輸出:m”是素?cái)?shù)”輸出:m”不是素?cái)?shù)”#include<stdio.h>#include<math.h>main(){int

m,i,k;

scanf("%d",&m);k=sqrt(m);

for(i=2;i<=k;i++)

if(m%i==0)break;

if(i>=k+1)

printf("%disaprimenumber\n",m);else

printf("%disnotaprimenumber\n",m);}算法:從i=3開始做分別用2,3,4,…√i除i.如果i被某個(gè)數(shù)整除,i是素?cái)?shù)。i++;測試下一個(gè)i;

main(){intm,k,i,n=0;for(m=3;m<=1000;m=m+2){k=sqrt(m);for(i=2;i<=k;i++)if(m%i==0)break;if(i>k+1)

{

printf(“%d”,m);

溫馨提示

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

最新文檔

評論

0/150

提交評論