C語言程序設計案例教程(三)131_第1頁
C語言程序設計案例教程(三)131_第2頁
C語言程序設計案例教程(三)131_第3頁
C語言程序設計案例教程(三)131_第4頁
C語言程序設計案例教程(三)131_第5頁
已閱讀5頁,還剩126頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

Date:04May2023C語言程序設計案例教程(三)Date:04五月2023第三章結構化程序設計授課要點循環(huán)的嵌套結構問題:打印如以下圖案123456789123456789123456789123456789123456789112123123412345問題解答1#include<stdio.h>voidmain(){ inti,j; for(i=1;i<=5;i++) { for(j=1;j<=9;j++) printf("%d",j); printf("\n"); } }問題解答2#include<stdio.h>voidmain(){ inti,j; for(i=1;i<=5;i++) { for(j=1;j<=i;j++) printf("%d",j); printf("\n"); } }問題:打印如以下圖案******************************問題解答3#include<stdio.h>voidmain(){ inti,j; for(i=1;i<=5;i++) { for(j=1;j<=i;j++) printf(“*"); printf("\n"); } }問題解答4#include<stdio.h>voidmain(){ inti,j; for(i=1;i<=5;i++) { for(j=1;j<=5-i;j++) printf(""); for(j=1;j<=i;j++) printf("*"); printf("\n"); } }問題:打印如以下圖案*************************問題解答5#include<stdio.h>voidmain(){ inti,j; for(i=1;i<=5;i++) { for(j=1;j<=5-i;j++) printf(""); for(j=1;j<=2*i-1;j++) printf("*"); printf("\n"); } }模仿練習*******************************************************小組討論并總結循環(huán)嵌套的執(zhí)行過程“控制流程〞編碼中的常見錯誤。結論1——循環(huán)嵌套的執(zhí)行過程執(zhí)行順序:1、語句12、判斷表達式:如果為假,執(zhí)行語句5;如果為真執(zhí)行另一個循環(huán)語句塊3、執(zhí)行語句24、判斷表達式2:如果為假,執(zhí)行語句4,轉回表達式1;如果為真,循環(huán)執(zhí)行語句3結論2——“控制流程〞中常見錯誤if…else不配對switch中表達式類型與case語句的值不匹配無結束條件,死循環(huán)循環(huán)次數(shù)不清楚誤用break和continue學以致用尋找你身邊的一個實際問題,構造出解決問題的表達式,描述解決問題的算法,以及編寫解決問題的程序。例如:假設你在某公司工作,老板要你打印一張表,買主可以用它來購置多個特定部件的費用。單個部件的價格從1元到9元不等。N件東西的費用就是單價與數(shù)量相乘得出。因此,你要打印一張像下面這樣的數(shù)字表: 某公司部件費用明細表1234567892468101214161836912151821242748121620242832362007年4月7日作業(yè)【練習1】將1、2、3、…、9打印15行?!揪毩?】打印如以下圖案: * *** ***** ****************【練習3】打印九九乘法表,如下圖Date:04五月2023第三章結構化程序設計授課要點循環(huán)的嵌套結構嵌套結構的轉換問題:輸入一個數(shù)n,求其階乘分析規(guī)律:1!=12!=2*1 =2*1!3!=3*2*1 =3*2!4!=4*3*2*1 =4*3!… …n!=n*(n-1)*(n-2)*…*3*2*1 =n*(n-1)!利用循環(huán)結構來實現(xiàn)編程思路〔1〕用變量n保存待計算階乘數(shù)的數(shù)據(jù),用p保存逐項累乘的結果,初值為1;〔2〕循環(huán)變量i的初值為1;〔3〕如果i超過n值,循環(huán)結束,轉〔6〕;〔4〕每次循環(huán),將變量i與p相乘,結果保存到p中;〔5〕循環(huán)變量i增加1,轉回到〔3〕;〔6〕輸出累乘結果p,結束運行。流程圖及代碼intn; /*存儲計算階乘的n值*/scanf(“%d〞,&n);/*取得輸入值n*/intj; /*循環(huán)變量j*/intp; /*累乘結果p*/for(j=1;j<=n;j++){ p=p*j;/*累乘,結果放到p中*/}printf(“%d〞,p);/*輸入累乘結果*/問題:求1!+2!+3!+…+20!的值分析:1、1-20分別求階乘(p1,p2,…,p20),然后求各個階乘的和。2、兩重循環(huán)解決問題

內重循環(huán):n!=1×2×3×…×n的實現(xiàn) 外重循環(huán):p1+p2+p3+p4+…+p20的實現(xiàn)嵌套循環(huán)流程圖循環(huán)嵌套——雙重循環(huán)兩個while循環(huán)嵌套while(…){while(…){

語句;}}內重循環(huán)外重循環(huán)兩個for循環(huán)嵌套for(…){for(…){

語句;}}雙重循環(huán)代碼分解/*內重循環(huán)代碼*/intj;/*循環(huán)變量*/p=1;for(j=1;j<=i;j++) p*=j;/*外重循環(huán)代碼*/inti; /*循環(huán)變量*/intsum=0;/*求和結果*/for(i=1;i<=20;i++){ sum=sum+p;/*累加*/}printf(“%d〞,sum);給出一個個i值得到p值雙重循環(huán)代碼塊while雙重循環(huán) inti=1; intsum=0; while(i<=20) { intj=1; intp=1; while(j<=i) { p=p*j;/*累乘積*/ j++; } i=i+1; sum=sum+p; }相應的for雙重循環(huán) inti,j,sum=0; intp=1; for(inti=1;i<=20;i++) { for(intj=1;j<=i;j++) { p=p*j;/*累乘積*/ } sum=sum+p; }問題擴展在問題中,采用的是兩個while和for循環(huán)的嵌套。能不能換成兩個do…while循環(huán)的嵌套?能不能換成for、do…while、while的混合型嵌套?for循環(huán)和do…while循環(huán)互換inti=1;intp=1;while(i<=20){

intj=1;for(intj=1;j<=i;j++){p=p*j;}

i=i+1;sum=sum+p;}inti=p=1;while(i<=20){ intj=1;

do { p=p*j; j++; }while(j<=i); i=i+1; sum=sum+p; }問題:搬運磚塊假設有36塊磚,共需36個人搬,男人可搬4塊,女人可搬3塊,小孩兩人搬1塊,要求一次全部搬完,問男、女、小孩人數(shù)的可能組合。思路:男人的可能值是0~8;女人的可能值是0~11;小孩的取值是〔36-男人-女人〕。問題:求100~200之間的全部素數(shù)什么是素數(shù)?如何判斷m是否是素數(shù)?思路:讓m被2到根號m除,如果m能被其中任何一個整數(shù)整除,那么m不是素數(shù)。小組討論并總結循環(huán)主菜單是如何跳出循環(huán)的?結論3——循環(huán)主菜單如何跳出循環(huán)?voidmain(){intinput;scanf(“%d〞,&input);switch(input){case1: /*語句*/ break;/*跳出循環(huán)*/case2: /*語句*/ break;/*跳出循環(huán)*/ …}}使用break語句Date:04五月2023第四章模塊化程序設計授課要點什么是結構化程序設計函數(shù)的定義、聲明、調用無參無返回值的函數(shù)無參有返回值的函數(shù)什么是結構化程序設計? 自上而下逐步細化的模塊化程序設計方法結構化程序設計的好處是什么? 復雜問題簡單化 便于多人協(xié)作完成一個大的任務 提高程序可維護性、可讀性 模塊復用C語言中如何實現(xiàn)結構化程序設計? 模塊化在C語言中用函數(shù)實現(xiàn)結構化程序設計#include<stdio.h>#include<math.h>main()//主函數(shù){ intiNo,b; printf(“inputanumber:\n〞);//輸出函數(shù) scanf(“%d〞,&iNo);//輸入函數(shù) b=sqrt(iNo);//求平方根函數(shù) printf(“%d〞,b);//輸出函數(shù)}初識函數(shù)1/*從鍵盤輸入3個數(shù),求和并輸出。*/#include<math.h>#include<stdio.h>intmyAdd(intx,inty,intz){ ints; s=x+y+z; returns;}main()//主函數(shù){ intiNo1,iNo2,iNo3,sum; printf("input3numbers:\n");//輸出函數(shù)

scanf("%d%d%d",&iNo1,&iNo2,&iNo3);//輸入函數(shù)

sum=myAdd(iNo1,iNo2,iNo3);//用戶自定義函數(shù)

printf("sum=%d",sum);//輸出函數(shù)}初識函數(shù)2函數(shù): 一段函數(shù)就是一段實現(xiàn)一定功能的代碼,就像一臺具有某種功能機器。因此函數(shù)的調用就類似啟動一臺機器來完成某個任務。C語言中,函數(shù)是實現(xiàn)模塊化的工具。什么是函數(shù)?用函數(shù)解決問題 輸入假設干個學生的學號、某門課程的平時成績和期末成績,計算出總評成績。其中, 總評成績=50%*平時成績+50%*期末成績 最后,從鍵盤輸入一個學生的學號,查詢該生的平時成績、期末成績和總評成績。用函數(shù)解決的思路 定義假設干具有不同功能的函數(shù),在main函數(shù)中分別調用它們,用以解決這個問題。如:main(){//定義必要的變量inputScore();//輸入學生學號及成績信息computeTotalScore();//計算每個學生的總成績searchByNo();//按學號查找某個學生的信息printSearchInfo();//輸出查找到的學生信息}main函數(shù)只負責解決問題的流程;具體子問題的實現(xiàn)交給不同的函數(shù)去處理。函數(shù)的定義除了系統(tǒng)提供的函數(shù)外,我們都需要對函數(shù)進行定義。函數(shù)定義的通用形式為:返回值數(shù)據(jù)類型函數(shù)名稱([參數(shù)數(shù)據(jù)類型參數(shù)1[,參數(shù)數(shù)據(jù)類型參數(shù)2,…]])

{

…}函數(shù)首部函數(shù)體函數(shù)定義例如(1)無參數(shù)無返回值的函數(shù)如:定義printStar函數(shù),用以在屏幕上輸出5個*符號。voidprintStar(){intstar;for(star=1;star<=5;star++) printf("*");printf("\n");}函數(shù)無返回值時使用的數(shù)據(jù)類型函數(shù)的調用無參的調用形式:函數(shù)名();無參數(shù)無返回值的函數(shù)的調用#include<stdio.h>main(){

printStar();//函數(shù)調用}voidprintStar(){intstar;for(star=1;star<=5;star++) printf("*");printf("\n");}自定義函數(shù)的聲明 在程序的開頭加上對應函數(shù)的聲明,就不會出現(xiàn)函數(shù)未定義(或重復定義)的錯誤。函數(shù)聲明的形式:返回值類型函數(shù)名稱([參數(shù)類型參數(shù)1,…]);其中前面的與函數(shù)定義時的首部完全一樣,但末尾必須加“;〞。如對printStar函數(shù)的聲明為:voidprintStar();無參數(shù)無返回值的函數(shù)的聲明#include<stdio.h>voidprintStar();//函數(shù)聲明main(){printStar();//函數(shù)調用}voidprintStar()//函數(shù)定義(首部){intstar;for(star=1;star<=5;star++) printf("*");printf("\n");}問題:過年回家,車票難買,到處托人。假設你先把車票錢給幫你買車票的朋友,那么返回給你的應該是一張車票〔當然要順利的話〕。同理,在C語言中,函數(shù)的調用有時候也是有返回值的,那么如何理解?分析

對應到函數(shù)上,你的朋友就是函數(shù),車票錢是函數(shù)輸入,車票就是函數(shù)的返回值,而你就是調用函數(shù)的主程序。

函數(shù)的返回值函數(shù)的返回值返回語句形式:return(表達式);或return表達式;或return;功能:使程序控制從被調用函數(shù)返回到調用函數(shù)中,同時把返值帶給調用函數(shù)函數(shù)定義例如(2)無參數(shù)有返回值的函數(shù) 如定義函數(shù)sum_100,用以求1+2+3+…+100的和,并將結果返回給調用它的函數(shù)。

intsum_100(){ints=0,i;for(i=1;i<=100;i++) s=s+i;

returns;

//用return返回一個值給主調函數(shù)

}無參數(shù)有返回值的函數(shù)例如

#include<stdio.h>

intsum_100();

//函數(shù)聲明

main(){ints1;

s1=sum_100();

//函數(shù)調用

printf("和值為:%d\n",s1);}intsum_100()//函數(shù)定義(首部){ints=0,i;for(i=1;i<=100;i++) s=s+i;

returns;

//返回值給主調函數(shù)

}模仿練習無參無返回值函數(shù)編寫:1、自定義函數(shù)myPrint1(),在屏幕上輸出如以下圖形(每行10個$符號),并在主函數(shù)中調用myPrint1()函數(shù)。$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$模仿練習無參無返回值函數(shù)編寫:2、自定義函數(shù)myPrint2(),在屏幕上輸出如以下圖形,并在主函數(shù)中調用myPrint2()函數(shù)。@@@@@@@@@@@@@@@@@@@@@@@@@模仿練習無參有返回值函數(shù)編寫:3、自定義函數(shù)myFac(),計算10!,將計算結果返回給調用者。然后在主函數(shù)中調用myFac()函數(shù),輸出該結果。4、自定義函數(shù)myMax(),實現(xiàn)功能:從鍵盤輸入3個數(shù),求最大數(shù)并在主函數(shù)中調用myMax()函數(shù),輸出該結果。小組討論并總結1、為什么使用函數(shù)?2、如何理解函數(shù)調用與函數(shù)定義的不同?3、空函數(shù)在程序結構設計中有什么作用?學以致用尋找你身邊的一個實際問題,編寫解決問題的程序,用到函數(shù)定義和調用。例、電視是我們日常生活中所熟悉的,我們通過遙控器選擇不同的頻道,就可以播放相應的頻道。請定義一個函數(shù)tvPlay(intchannel),模擬根據(jù)遙控器的輸入的頻道號碼,播放相應的頻道。然后給出調用的例子,比方,遙控器上選擇5,那么播放CCTV-5體育頻道。作業(yè)——每人必做1、編寫一個函數(shù)sum(n),計算1+2…+n之和,根據(jù)n值的不同,得到不同的值。要求分別計算n=50,n=80,n=100的情況。2、將自己的“學生成績管理系統(tǒng)〞〔循環(huán)菜單〕以模塊化的形式進行處理,具體實施方案:主菜單的顯示和選擇局部可定義函數(shù)menu_select〔〕來調用,“編輯子菜單〞可定義editmenu〔〕來調用,“查找〞可定義serachmenu〔〕來調用。作業(yè)——小組必做尋找你身邊的一個實際問題,構造出解決問題的表達式,描述解決問題的算法,以及編寫解決問題的程序。例如,MP3可以播放不同的歌曲,請編寫一個MP3模擬函數(shù),根據(jù)輸入不同的歌曲代號,可以顯示相應的歌曲名。然后,調用該函數(shù)。Date:04五月2023第四章模塊化程序設計授課要點有參無返回值的函數(shù)有參有返回值的函數(shù)函數(shù)定義例如(3)有參數(shù)無返回值的函數(shù)如定義printStar_n()函數(shù),用以在屏幕的一行上輸出n個*號。其中n的值是由調用該函數(shù)的函數(shù)傳遞過來的。

voidprintStar_n(intn){ intstar;for(star=1;star<=n;star++) printf("*"); printf("\n");}函數(shù)參數(shù)(稱為形參)函數(shù)調用有參函數(shù)的調用形式: 函數(shù)名〔實參〕;實參與形參:個數(shù)相等類型一致按順序一一對應有參數(shù)無返回值的函數(shù)調用

#include<stdio.h>

voidprintStar2(intn);//函數(shù)聲明

main(){intstarNum;scanf("%d",&starNum);printStar_n(starNum);//函數(shù)調用

}

voidprintStar_n(intn)//函數(shù)定義(首部){intstar;for(star=1;star<=n;star++) printf("*"); printf("\n");}函數(shù)參數(shù)(稱為形參)調用時傳遞的參數(shù)(稱為實參)函數(shù)定義例如(4)有參數(shù)有返回值的函數(shù)如定義函數(shù)sum_n(),用以求1+2+3+…+n的和,并將結果返回給調用它的函數(shù)。

intsum_n(intn){ ints=0,i;for(i=1;i<=n;i++) s=s+i;

returns;

//通過return返回一個值

}函數(shù)參數(shù)(稱為形參)

#include<stdio.h>

intsum_n(intn);//函數(shù)聲明

main(){ints1,n;scanf("%d",&n);

s1=sum_n(

n);

//函數(shù)調用

printf("和值為:%d\n",s1);}

intsum_n(n)//函數(shù)定義(首部){ints=0,i;for(i=1;i<=n;i++) s=s+i;

returns;

//返回一個值給主調函數(shù)

}有參數(shù)有返回值的函數(shù)調用函數(shù)的調用1、語句調用方式2、函數(shù)表達式3、函數(shù)參數(shù)函數(shù)的調用調用方式語句調用:例printmsg();printf(“打印成功!\n〞);函數(shù)表達式調用:例result=aver(totalscore,stuno);函數(shù)參數(shù)調用:例printf(“%f〞,aver(totalscore,stuno));

隨堂實踐有參無返回值函數(shù)編寫:1、自定義函數(shù)myprint_n(),在屏幕的一行上輸出n個$符號。在主函數(shù)中調用myprint_n()函數(shù),輸出如以下圖形(每行上的符號個數(shù)由調用它的函數(shù)傳遞過來)。函數(shù)首部為:voidmyprint_n(intn)$$$$$(5個$)$$$$$$$$$$(10個)$$$$$$$$$$$$$$$(15個)$$$$$$$$$$$$$$$$$$$$(20個)2、修改以上程序,實現(xiàn)以下功能:打印個數(shù)由用戶輸入決定,支持用戶循環(huán)輸入,當用戶輸入0時結束程序。有參有返回值函數(shù)編寫:3、自定義函數(shù)myfac_n(),求n!,并在主函數(shù)中調用myfac_n()函數(shù),輸出結果。函數(shù)首部為:intmyfac_n(intn)4、自定義函數(shù)mypower(),求x的y次冪,并在主函數(shù)中調用mypower()函數(shù),輸出結果。函數(shù)首部為:doublemypower(doublex,inty)5、自定義函數(shù)circleArea(),用于計算圓的面積,其中半徑作為參數(shù)傳入。然后在主函數(shù)中調用它,并輸出結果。函數(shù)首部為:doublecircleArea(doubleradius)

隨堂實踐小組討論并總結1、函數(shù)的功能應該盡量保持相對獨立還是依賴函數(shù)外的數(shù)據(jù)為好?2、怎樣使一個函數(shù)具有更大的通用性?3、函數(shù)參數(shù)的值傳遞有哪些特點?學以致用尋找你身邊的一個實際問題,編寫解決問題的程序,要求用到函數(shù)調用、參數(shù)傳遞。例如:踢足球的時候,裁判要求換人,比方要用8號換下18號,請用函數(shù)模擬換人,并在主函數(shù)中調用。作業(yè)——每人必做將“控制流程〞階段完成的“小型計算器〞功能改寫為函數(shù),并在主函數(shù)中調用,注意參數(shù)的類型定義及傳參過程。Date:04五月2023第四章模塊化程序設計授課要點復習,評講模擬練習參數(shù)的值傳遞實訓函數(shù)的值傳遞方式#include<stdio.h>voidmain(){voidswap(inta,intb);/*swap函數(shù)的聲明*/intx=7,y=11;printf("x=%d,\ty=%d\n",x,y);printf("swapped:\n");swap(x,y);/*調用swap函數(shù)*/printf("x=%d,\ty=%d\n",x,y);}voidswap(inta,intb)/*定義swap函數(shù)*/{inttemp;temp=a;a=b;b=temp;輸出結果:x=7,y=11}swapped:x=7,y=11結論:值傳遞方式方式:函數(shù)調用時,為形參分配單元,并將實參的值復制到形參中;調用結束,形參單元被釋放,實參單元仍保存并維持原值特點:形參與實參占用不同的內存單元單向傳遞結論:函數(shù)參數(shù)的傳遞方式還有另一種---地址傳遞方式其傳遞的參數(shù)為地址而不是值,具體內容將在數(shù)組章節(jié)中學習.Date:04五月2023第四章模塊化程序設計授課要點作業(yè)評講變量的存儲類別問題#include<stdio.h>voidprt();main(){intx;for(x=1;x<=5;x++) prt();}voidprt(){ staticinty=0;y++; printf("%d",y);}輸出結果:12345去掉static后的結果為多少?問題分析動態(tài)存儲變量和靜態(tài)存儲變量動態(tài)變量:用auto關鍵字表示如autointp,f;//p,f為兩個動態(tài)變量在C中,默認的變量定義就是定義為動態(tài)變量即上述的p,f變量定義與intp,f;是完全等價的。靜態(tài)變量:在程序生存期內一直有效。注意,如果靜態(tài)變量出現(xiàn)在函數(shù)中,不會因為函數(shù)的調用結束而喪失這個變量的值變量的生存期inta,b,c;//外部變量定義main(){intx,y;//內部變量

floatf;//內部變量

//其他語句…}intsum(intn){ints=0,i;//內部變量

//語句}x,y,f的有效區(qū)域s,i的有效區(qū)域a,b,c的有效區(qū)域內部變量與外部變量的作用區(qū)域是不一樣的。1.變量的存儲類型計算機的存儲器分為內存和外存。還有一個小小的臨時存儲器稱為存放器,用以存儲一些反復被加工的數(shù)據(jù)。C語言允許程序員區(qū)分是在主存還是在存放器中開辟變量的存儲空間。2.變量的生存期〔1〕在編譯時分配存儲單元。這種變量的生存期為程序執(zhí)行的整個過程,在該過程中占有固定的存儲空間,稱為永久存儲?!?〕只在程序執(zhí)行的某一段時間內存在。比方在函數(shù)的執(zhí)行過程中存在。這種存儲方式稱為動態(tài)存儲。小結小結3.變量的可用域變量的可用域也分為全局可用和局部可用。C語言中,用“存儲屬性〞來表示以上三個方面的屬性,如表所示。名稱寄存器變量自動變量靜態(tài)變量外部變量存儲屬性registerautostaticextern存儲位置寄存器主存生存期動態(tài)生存期永久生存期作用域局部局部或全局全局模仿練習1、寫出以下程序的運行結果:int

fun(inta) /*a為形參,自動型局部變量*/{autointb=0; /*b是自動型局部變量*/staticintc=3; /*c是靜態(tài)型局部變量,初始化僅進行一次*/b+=1;c=c+1;returna+b+c;}main(){inta=2,i; /*a和i都是自動型局部變量*/for(i=0;i<3;i++)printf("%d\t",fun(a));}模仿練習2、寫出以下程序的運行結果:intsum(intn);//函數(shù)聲明inta=4,b=5,c=6;//外部變量定義main(){intx=1,y=2;floatf=3.0;x=sum(10);printf("x=%d,y=%d,f=%f\n",x,y,f); printf("a=%d,b=%d,c=%d\n",a,b,c);//printf("s=%d,i=%d\n",s,i);}intsum(intn){ints=0,i;for(i=1;i<=n;i++)s=s+i;printf("s=%d,i=%d\n",s,i);printf("a=%d,b=%d,c=%d\n",a,b,c);//printf("x=%d,y=%d,f=%f\n",x,y,f);returns;}Date:04五月2023第四章模塊化程序設計授課要點函數(shù)的嵌套調用函數(shù)的遞歸調用函數(shù)的嵌套調用f1(){…f2();…}f2(){…f3();…}f3(){………}函數(shù)的嵌套調用舉例1main(){inta=3,b=5,s;s=cal(a,b);printf(“%d〞,s);}intcal(intx,inty){intresult,s1,s2;s1=powl(x,y);s2=pow(y,x);result=s1+s2;returnresult;}intpow(intm,intn){inti,res=1;for(i=0;i<n;i++)res*=m;returnres;}求3+5。53函數(shù)的嵌套調用舉例2自定義函數(shù)mymax2(),求出2個參數(shù)的最大值,然后定義函數(shù)mymax3(),調用mymax2()求出3個參數(shù)中的最大值,將值返回給主函數(shù),輸出該結果。函數(shù)首部為:floatmymax3(floatx,floaty,floatz)

模仿練習1、自定義函數(shù)mymax(),求出3個參數(shù)的最大值;自定義函數(shù)mymin(),求出3個參數(shù)的最小值;自定義函數(shù)mysub(),調用mymax()和mymin()求出3個參數(shù)的最大值與最小值的差;在主函數(shù)中調用mysub(),輸出結果。 函數(shù)首部為:floatmymax(floatx,floaty,floatz) floatmymin(floatx,floaty,floatz)floatmysub(floatx,floaty,floatz)2、計算s=1k+2k+3k+……+Nk函數(shù)首部為:longf1(intn,intk) /*計算n的k次方*/

longf2(intn,intk) /*計算1到n的k次方之累加和*/

案例解答#defineK4#defineN5longf1(intn,intk) /*計算n的k次方*/{longpower=n;inti;for(i=1;i<k;i++)power*=n;returnpower;}longf2(intn,intk) /*計算1到n的k次方之累加和*/{longsum=0; inti;for(i=1;i<=n;i++)sum+=f1(i,k);returnsum;}main(){printf("Sumof%dpowersofintegersfrom1to%ld=",K,N);printf("%d\n",f2(N,K));}函數(shù)的遞歸調用C語言的函數(shù)調用允許直接或間接地調用該函數(shù)本身,稱為函數(shù)的遞歸調用。含有直接或間接調用自己的函數(shù)稱為遞歸函數(shù)。函數(shù)f調用函數(shù)f函數(shù)f1調用函數(shù)f2調用函數(shù)f1函數(shù)f2直接調用本身間接調用本身函數(shù)的遞歸調用舉例用遞歸函數(shù)求4!4!=4*3!;3!=3*2!;2!=2*1!;1!=1;n!=n*(n-1)!1!=1函數(shù)的遞歸調用舉例例:用遞歸函數(shù)求n!n!=n*(n-1)!intmyFac(intn){if(n==1)return1;//遞歸的結束條件

returnn*myFac(n-1);}myFac(n)就是求n!myFac(n-1)就是求(n-1)!函數(shù)的遞歸調用舉例fac(3)*4fac(2)*3fac(1)*2reutrn(1)reutrn(1*2)reutrn(2*3)return(6*4)調用過程返回過程fac(4)reutrn(24)用遞歸函數(shù)求4!函數(shù)的遞歸調用舉例例:用遞歸函數(shù)求n!的完整程序#include<stdio.h>intmyFac(intn);main(){ intf,n; scanf("%d",&n); f=myFac(n); printf("%d!=%d\n",n,f);}intmyFac(intn){ ints;if(n==1) s=1;//遞歸的結束條件

elses=n*myFac(n-1);returns;}單步調試,理解遞歸程序的執(zhí)行流程函數(shù)的遞歸調用舉例遞歸算法的組成:遞歸終止條件:當滿足一定條件時,遞歸調用必須可以結束,否那么會無限地遞歸調用而導致程序無法結束。例如n!中當n=1時,令結果為1那么可以結束遞歸調用,否那么它將繼續(xù)調用(0)!而無限繼續(xù)下去。對于由多個通項表示的情況,那么需要給出最后一個遞歸調用的所有項的值。如an=an-1+an-2,要給出n=1時的結果以及n=2時結果才可以結束遞歸調用。遞歸表達式,如fac(n)=n*fac(n-1)函數(shù)的遞歸調用舉例求下數(shù)列的第20項的值。1,2,3,5,8,13,21,34……a1=1;a2=2;a3=a1+a2;…an=an-1+an-2;

函數(shù)的遞歸調用舉例求下數(shù)列的第20項的值。1,2,3,5,8,13,21,34……f(1)=1;f(2)=2;f(n)=f(n-1)+f(n-2);

函數(shù)的遞歸調用舉例main(){inta;a=f(20);printf(“%d〞,a);}intf(intn){ints;if(n==1)s=1;elseif(n==2)s=2;elses=f(n-1)+f(n-2);returns;}

模仿練習遞歸函數(shù)的編寫:1、用遞歸方法編寫函數(shù)求n!。函數(shù)定義如下:intrecFac(intn)2、用遞歸函數(shù)的方法編寫函數(shù)求斐波納契〔Fibonacci〕數(shù)列的第20項的值。函數(shù)定義如下:intFib(intn)其中n為該數(shù)列中的第n項。1,1,2,3,5,8,13……模仿練習遞歸函數(shù)的編寫:3、用遞歸算法,計算:1+2+3+…+n2222Date:04五月2023第四章模塊化程序設計授課要點數(shù)組的概念一維數(shù)組的定義和引用一維數(shù)組的初始化和賦值數(shù)組元素的遍歷

這樣做好嗎? 如果題目改為10個數(shù)、100個數(shù)該怎么做?

問題1:從鍵盤輸入5個整數(shù),逆序輸出這5個數(shù)。main(){ inta0,a1,a2,a3,a4; scanf(“%d〞,&a0); scanf(“%d〞,&a1); scanf(“%d〞,&a2); scanf(“%d〞,&a3); scanf(“%d〞,&a4); printf(“%d\n〞,a4); printf(“%d\n〞,a3); printf(“%d\n〞,a2); printf(“%d\n〞,a1); printf(“%d\n〞,a0);}在“學生成績管理系統(tǒng)〞中,我們需要對多個學生進行處理,比方100個學生,是否必須定義100個變量呢? Studentstu1; Studentstu2; Studentstu3; … Studentstu100;定義多個變量,在定義、輸入、輸出、處理的時候非常不方便。如果需要處理5000個學生的成績,情況就更糟。問題2以上兩個例子有什么共同之處?問題2具有相同的數(shù)據(jù)類型!數(shù)組的概念數(shù)組是一組變量,滿足以下條件:

〔1〕具有相同的名字

〔2〕具有相同的數(shù)據(jù)類型

〔3〕在存儲器中連續(xù)存放每個變量名字相同下標不同,稱為“數(shù)組元素〞“數(shù)組名〞代表整個數(shù)組,其值是這組變量在內存中所占連續(xù)存儲空間的首地址。數(shù)組要先定義后使用。數(shù)組名不能與相同作用域的其他變量名重名問題如何定義數(shù)組?如何為數(shù)組元素賦值?如何引用數(shù)組元素?一維數(shù)組的定義一維數(shù)組:只有一個下標的數(shù)組定義形式為:類型說明符數(shù)組名[常量表達式]例如:inta[10];說明數(shù)組名為a數(shù)組中每個元素的數(shù)據(jù)類型為int類型10個數(shù)組元素[]內是常量表達式,不能為變量1、定義100個整型變量2、定義50個浮點型變量3、定義1000個“學生〞變量,“學生〞類型定義如下:typedefstruct{ characNum[10]; characName[15]; ……}Student;模仿練習以下一維數(shù)組的定義是否正確?

inta[];#defineSIZE100floatb[SIZE];intn=10;charc[n];int2a[10];錯誤,沒有指明數(shù)組的大小inta[10];正確,SIZE是常量,相當于floatb[100];錯誤,數(shù)組的大小不能是變量,應為inta[10];錯誤,數(shù)組名2a不符合標識符的命名規(guī)則數(shù)組元素的引用數(shù)組就是一組變量的集合,每個數(shù)組元素相當于是一個變量數(shù)組元素的表示:數(shù)組名[下標]如:inta[5];所定義的數(shù)組就是五個變量的集合,分別是: a[0],a[1],a[2],a[3],a[4]inta[N];下標的取值范圍:0~N-1,其中N為數(shù)組的大小下標是整型值,可以是整型常量、整型變量或整型表達式如:a[i]a[3+1]a[2*i-1]注意:下標不能越界,否那么可能覆蓋其他數(shù)據(jù),造成嚴重后果定義數(shù)組之后,與普通變量一樣,數(shù)組是沒有初始值的,各存儲單元的值都是不定的。初始化:定義數(shù)組的同時賦初值語法:數(shù)據(jù)類型說明符數(shù)組名[長度]={數(shù)值1,數(shù)值2,…};

如:intdata[10]={0,1,2,3,4,5,6,7,8,9};一維數(shù)組的初始化1、定義并初始化一個float型數(shù)組,包含5個元素。2、定義并初始化一個字符型數(shù)組,包含6個元素。3、定義一個全0的整形數(shù)組,包含15個元素。模仿練習初始化本卷須知:(1)允許初始化一局部元素,其他沒有賦初值的元素初值為0;inta[10]={0,1,2,3,4,5};相當于inta[10]={0,1,2,3,4,5,0,0,0,0};(2)允許初始化時省略數(shù)組的長度,數(shù)組的長度

溫馨提示

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

評論

0/150

提交評論