




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
實驗報告工學(xué)院土木工程專業(yè)09級2011至2012學(xué)年度第1學(xué)期學(xué)號:xxxxxx姓名:xxxxxx2011年12月1日第3~4節(jié)綜合樓325教室進(jìn)入實驗室時間同組者離開實驗室時間實驗項目名稱09:50無11:30實驗七函數(shù)(二)實驗?zāi)康模?、進(jìn)一步熟悉怎樣利用函數(shù)實現(xiàn)指定的任務(wù);2、熟悉函數(shù)的嵌套調(diào)用和遞歸調(diào)用的方法;3、熟悉全局變量和局部變量的概念和用法;實驗內(nèi)容(1)寫一個函數(shù),用“起泡法”對輸入的10個字符按由小到大順序排列。①輸入程序,進(jìn)行編譯和運(yùn)行,分析結(jié)果。輸入程序如下:#include<stdio.h>#include<string.h>#defineN10charstr[N];intmain(){voidsort(char[]);inti,flag;for(flag=1;flag==1;){printf("inputstring:\n");scanf("%s",&str);if(strlen(str)>N)printf("stringtoolong,inputagain!");elseflag=0;}sort(str);printf("stringsorted:\n");for(i=0;i<N;i++)printf("%c",str[i]);printf("\n");return0;}voidsort(charstr[]){inti,j;chart;for(j=1;j<N;j++)for(i=0;(i<N-j)&&(str[i]!='\0');i++)if(str[i]>str[i+1]){t=str[i];str[i]=str[i+1];str[i+1]=t;}}運(yùn)行結(jié)果如下:②將要排序的字符串改為5個,按由大到小的順序排列。輸入程序如下:#include<stdio.h>#include<string.h>#defineN5charstr[N];intmain(){voidsort(char[]);inti,flag;for(flag=1;flag==1;){printf("inputstring:\n");scanf("%s",&str);if(strlen(str)>N)printf("stringtoolong,inputagain!");elseflag=0;}sort(str);printf("stringsorted:\n");for(i=0;i<N;i++)printf("%c",str[i]);printf("\n");return0;}voidsort(charstr[]){inti,j;chart;for(j=1;j<N;j++)for(i=0;(i<N-j)&&(str[i]!='\0');i++)if(str[i]<str[i+1]){t=str[i+1];str[i+1]=str[i];str[i]=t;}}運(yùn)行結(jié)果如下:(2)用遞歸法將一個整數(shù)n轉(zhuǎn)換成字符串。n的位數(shù)不確定,可以使任意的整數(shù)。①輸入程序,進(jìn)行編譯和運(yùn)行,分析結(jié)果。輸入程序如下:#include<stdio.h>intmain(){voidconvert(intn);intnumber;printf("inputaninteger:");scanf("%d",&number);printf("output:");if(number<0){putchar('-');putchar('');number=-number;}convert(number);printf("\n");return0;}voidconvert(intn){inti;if((i=n/10)!=0)convert(i);putchar(n%10+'0');putchar(32);}運(yùn)行結(jié)果如下:②分析遞歸調(diào)用的形式和特點。函數(shù)調(diào)用的一般形式為:函數(shù)名(實參表列)說明:1.如果是調(diào)用無參函數(shù),則“實參表列”可以沒有,但括弧不能省略。2.如果實參表列包含多個實參,則各參數(shù)間用逗號隔開。實參與形參的個數(shù)應(yīng)相等,類型應(yīng)匹配。實參與形參按順序?qū)?yīng),向形參傳遞數(shù)據(jù)。3.如果實參表列包括多個實參,對實參求值的順序并不是確定的,有的系統(tǒng)按自左至右順序求實參的值,有的系統(tǒng)則按自右至左順序。有兩種調(diào)用形式:直接遞歸----在函數(shù)體內(nèi)調(diào)用自身,間接遞歸----函數(shù)中調(diào)用其他函數(shù),并由其他函數(shù)調(diào)用自身特點:原問題可以分解為若干子問題分別進(jìn)行求解;適當(dāng)?shù)睾喜⒆訂栴}的解可以得到原問題的解;而子問題的求解方式與原問題的求解相同;因而需要調(diào)用相同的函數(shù)來實現(xiàn);由此而涉及到遞歸技術(shù)。③思考如果不用遞歸法,能否改用其他方法解決此問題,上機(jī)試一下。答:應(yīng)該有別的方法,但至今沒有想出來。(3)編寫一個函數(shù),由實參傳來一個字符串,統(tǒng)計此字符串中字母、數(shù)字、空格和其他字符的個數(shù),在主函數(shù)中輸入字符串以及輸出上述的結(jié)果。①在程序中用全局變量,編譯和運(yùn)行程序,分析結(jié)果。討論為什么要用全局變量。輸入程序如下:#include<stdio.h>intletter,digit,space,others;intmain(){voidcount(char[]);chartext[80];printf("inputstring:\n");gets(text);printf("string:");puts(text);letter=0;digit=0;space=0;others=0;count(text);printf("\nletter:%d\ndigit:%d\nspace:%d\nothers:%d\n",letter,digit,space,others);return0;}voidcount(charstr[]){inti;for(i=0;str[i]!='\0';i++)if((str[i]>='a'&&str[i]<='z')||(str[i]>='A'&&str[i]<='Z'))letter++;elseif(str[i]>='0'&&str[i]<='9')digit++;elseif(str[i]==32)space++;elseothers++;}運(yùn)行結(jié)果如下:分析:在函數(shù)內(nèi)定義的變量是局部變量,而在函數(shù)之外定義的變量稱為外部變量,外部變量是全局變量(也稱全程變量)。全局變量可以為本文件中其他函數(shù)所共用。它的有效范圍為從定義變量的位置開始到本源文件結(jié)束。在此題中,由于調(diào)用函數(shù)的返回值太多,所以運(yùn)用全局變量避免了返回時所造成的麻煩。故在此題中使用全局變量比較簡便。②能否不用全局變量,修改程序并運(yùn)行之。答:不能。使用局部變量后,在調(diào)用的函數(shù)中無法識別letter、digit、space和others等變量。必須重新定義并一一返回。此過程比較麻煩。(4)求兩個整數(shù)的最大公約數(shù)和最小公倍數(shù),用一個函數(shù)求最大公約數(shù)。用另一函數(shù)根據(jù)求出來的最大公約數(shù)求最小公倍數(shù)。①不用全局變量,分別用兩個函數(shù)求最大公約數(shù)和最小公倍數(shù)。兩個整數(shù)在主函數(shù)中輸入,并傳送給函數(shù)hcf,求出的最大公約數(shù)返回主函數(shù),最后再與兩個整數(shù)一起作為實參傳遞給函數(shù)lcd,求出最小公倍數(shù),返回到主函數(shù)輸出最大公約數(shù)和最小公倍數(shù)。輸入程序如下:#include<stdio.h>intmain(){inthcf(int,int);intlcd(int,int,int);intu,v,h,l;scanf("%d,%d",&u,&v);h=hcf(u,v);printf("H.C.F=%d\n",h);l=lcd(u,v,h);printf("L.C.D=%d\n",l);return0;}inthcf(intu,intv){intt,r;if(v>u){t=u;u=v;v=t;}while((r=u%v)!=0){u=v;v=r;}return(v);}intlcd(intu,intv,inth){return(u*v/h);}運(yùn)行結(jié)果如下:②用全局變量的方法。用兩個全局變量分別代表最大公約數(shù)和最小公倍數(shù)。用兩個函數(shù)分別求最大公約數(shù)和最小公倍數(shù),但其值不由函數(shù)帶回,而是賦給全局變量。在主函數(shù)中輸出他們的值。輸入程序如下:#include<stdio.h>intHcf,Lcd;intmain(){voidhcf(int,int);voidlcd(int,int);intu,v;scanf("%d,%d",&u,&v);hcf(u,v);lcd(u,v);printf("H.
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 【正版授權(quán)】 ISO/IEC 27403:2024 EN Cybersecurity – IoT security and privacy – Guidelines for IoT-domotics
- 2025年無機(jī)分離膜材料合作協(xié)議書
- 2025版安置房買賣合同范本:限價房交易政策范本
- 2025年度廠區(qū)門衛(wèi)智能化升級改造服務(wù)合同范本
- 2025年高壓清洗車合作協(xié)議書
- 社團(tuán)活動反饋與改進(jìn)方案計劃
- 教學(xué)資源整合與優(yōu)化策略計劃
- 企業(yè)未來發(fā)展的創(chuàng)新思考計劃
- 財務(wù)企劃管理計劃
- 建立健全院內(nèi)溝通反饋機(jī)制的計劃
- 白酒業(yè)務(wù)員考勤管理制度
- 小班班本課程《吃飯這件小事》
- 危險化學(xué)品事故應(yīng)急預(yù)案演練評估報告
- 部編人教版六年級道德與法治下冊全冊完整版課件
- 會議紀(jì)要督辦管理制度
- 電動車輛動力電池系統(tǒng)及應(yīng)用技術(shù) 第3版 課件全套 王震坡 第1-11章 動力電池及其驅(qū)動的電動車輛- 動力電池充電方法與基礎(chǔ)設(shè)施
- 2024云南中考數(shù)學(xué)二輪專題復(fù)習(xí) 題型五 二次函數(shù)性質(zhì)綜合題(課件)
- JB∕T 9006-2013 起重機(jī) 卷筒標(biāo)準(zhǔn)規(guī)范
- 家庭法律服務(wù)行業(yè)市場突圍建議書
- 高一數(shù)學(xué)同步優(yōu)品講練課件(人教A版2019必修第一冊)3.2 函數(shù)的基本性質(zhì)(課時3 函數(shù)的奇偶性)(課件)
- 太平洋保險計劃書模板
評論
0/150
提交評論