版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 信息科學(xué)與技術(shù)學(xué)院</b></p><p> 程序設(shè)計(jì)基礎(chǔ)課程設(shè)計(jì)報(bào)告</p><p> 題目名稱(chēng): Fibonacci 數(shù)列輸出系統(tǒng) </p><p> 學(xué)生姓名: 侯 明 </p><p> 學(xué) 號(hào):
2、 2011508026 </p><p> 專(zhuān)業(yè)班級(jí): 計(jì)算機(jī)科學(xué)與技術(shù)專(zhuān)業(yè)(1)班 </p><p> 指導(dǎo)教師: 鄭 瑤 </p><p> 2012年 7 月 2 日</p><p><b> 目 錄</b></p>
3、<p> 1 課程設(shè)計(jì)題目與要求3</p><p><b> 1.1設(shè)計(jì)題目3</b></p><p> 1.2設(shè)計(jì)要求.3</p><p><b> 2 總體設(shè)計(jì).4</b></p><p><b> 3 詳細(xì)設(shè)計(jì)5</b></p>
4、<p> 3.1數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)5</p><p> 3.2主模塊設(shè)計(jì)5</p><p> ?。?)數(shù)據(jù)操作模塊............................................................................................................5</p><p>
5、?。?)循環(huán)模塊....................................................................................................................6</p><p><b> 4 運(yùn)行結(jié)果7</b></p><p> 5 課程設(shè)計(jì)總結(jié)9</p>
6、<p> 6 參考文獻(xiàn)....10</p><p> 1 課程設(shè)計(jì)題目與要求</p><p> 1.1設(shè)計(jì)題目 :Fibonacci 數(shù)列輸出系統(tǒng)</p><p><b> 1.2設(shè)計(jì)要求:</b></p><p> (1)簡(jiǎn)單變量“數(shù)據(jù)平移”方法計(jì)算Fibonacci 數(shù)列的第n項(xiàng)(正數(shù)n通過(guò)鍵
7、盤(pán)輸入):說(shuō)明變量old1=1,old2=1,newitem:新的Fionacci項(xiàng)newitem總是“距它最近”的前兩項(xiàng)(old1與old2)的累加和。而后通過(guò)“old1=old2;old2=newitem;”進(jìn)行所謂的“數(shù)據(jù)平移”。接著計(jì)算另一個(gè)Fibonacci項(xiàng)newitem,依次循環(huán),直到求出數(shù)列的第n項(xiàng)時(shí)為止。</p><p> (2)使用數(shù)組求出Fibonacci數(shù)列的第n項(xiàng)(正整數(shù)n通過(guò)鍵盤(pán)輸入
8、)并顯示在屏幕上:說(shuō)明數(shù)組f用來(lái)存放Fibonacci數(shù)列的各項(xiàng)之值,且僅初始化前兩個(gè)元素f[0]=1,f[1]=1,而后通過(guò)f[i]=f[i-2]+f[i-1];一次計(jì)算出f[2]到f[n-1]</p><p> ?。ㄗ⒁鈌[n-1]恰為所要求出的第n項(xiàng))并將該值顯示在屏幕上。</p><p> (3)其他要求 </p><p> 只能使用c++或c語(yǔ)言
9、,源程序要有適當(dāng)?shù)淖⑨專(zhuān)乖摮绦蛉菀滓鬃x。</p><p> 至少采用文本菜單界面</p><p> 學(xué)生可自動(dòng)增加新功能模塊</p><p> 完成系統(tǒng)總結(jié)報(bào)告以及系統(tǒng)使用說(shuō)明書(shū)。</p><p><b> 總體設(shè)計(jì):</b></p><p><b> ?。?lt;/b>
10、</p><p><b> 詳細(xì)設(shè)計(jì)</b></p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì):</p><p> ?。?)通過(guò)簡(jiǎn)單變量“數(shù)據(jù)平移”方法計(jì)算Fibonacci 數(shù)列的第n項(xiàng)(正數(shù)n通過(guò)鍵盤(pán)輸入):說(shuō)明變量old1=1,old2=1,newitem:新的Fionacci項(xiàng)newitem總是“距它最近”的前兩項(xiàng)(old1與old2)的累加
11、和。而后通過(guò)“old1=old2;old2=newitem;”進(jìn)行所謂的“數(shù)據(jù)平移”。接著計(jì)算另一個(gè)Fibonacci項(xiàng)newitem,依次循環(huán),直到求出數(shù)列的第n項(xiàng)時(shí)為止。</p><p> 具體如下:long f[10000]; //定義一個(gè)數(shù)組來(lái)乘放斐波那契數(shù)列</p><p> int i,m ; //定義兩個(gè)變量來(lái)決定
12、斐波那契數(shù)列長(zhǎng)度</p><p> {f[i+2]=f[i+1]+f[i];} //數(shù)據(jù)平移及數(shù)組法求得斐波那契數(shù)列</p><p> ?。?)使用數(shù)組求出Fibonacci數(shù)列的第n項(xiàng)(正整數(shù)n通過(guò)鍵盤(pán)輸入)并顯示在屏幕上:說(shuō)明數(shù)組f用來(lái)存放Fibonacci數(shù)列的各項(xiàng)之值,且僅初始化前兩個(gè)元素f[0]=1,f[1]=1,而后通過(guò)f[i]=f[i-2]+f[i-1];一次計(jì)
13、算出f[2]到f[n-1]</p><p> 具體如下:for (i=0;i<=n;i++)</p><p><b> {</b></p><p> if (i==0||i==1)f[i]=1;</p><p> else f[i]=f[i-1]+f[i-2]; //定義一個(gè)數(shù)組f 進(jìn)行值傳遞
14、</p><p><b> }</b></p><p><b> 3.2主模塊設(shè)計(jì)</b></p><p><b> 1數(shù)據(jù)操作模塊</b></p><p> 圖3.2-1 數(shù)據(jù)操作模塊圖</p><p><b> 2選擇循環(huán)模塊
15、:</b></p><p><b> ?。?lt;/b></p><p> n=0 n<0</p><p> 圖 3.2-2選擇循環(huán)模塊圖</p><p><b> 4 運(yùn)行結(jié)果</b></p&
16、gt;<p><b> 截圖及說(shuō)明</b></p><p> 圖4-1 windows 侯明.exe程序執(zhí)行界面</p><p> 圖 4-2 windows 侯明.exe程序執(zhí)行過(guò)程中</p><p><b> 5 課程設(shè)計(jì)總結(jié)</b></p><p> 在計(jì)算F
17、ibonacci數(shù)列時(shí)需要循環(huán)相加,但首先要保證n的值是大于2的。在n的值為1或2的時(shí)候,f(n)=1。所以在進(jìn)行循環(huán)之前要先判斷n是否為1或2,將這兩種情況排除后才能利用公式f(n)=f(n-1)+f(n-2)進(jìn)行累加。這是在編寫(xiě)這個(gè)程序中需要注意的很重要的一部分。經(jīng)過(guò)抽其中幾項(xiàng),,本程序均能達(dá)到實(shí)驗(yàn)要求,得出正確的答案。</p><p> 經(jīng)過(guò)此次的課程設(shè)計(jì),我也學(xué)習(xí)到了c++課程設(shè)計(jì)的知識(shí)。</p&
18、gt;<p> 首先,在程序的制作過(guò)程中,遇到了很多意想不到的困難,自己一個(gè)人解決起來(lái)有難度,于是也少不了同學(xué)的幫助,深刻體會(huì)到開(kāi)發(fā)程序不只是一兩個(gè)人就能很好的完成的,要大家互相幫助,共同探討問(wèn)題,才能更好的解決困難。</p><p> 其次,編程設(shè)計(jì)中遇到了很多沒(méi)有學(xué)過(guò)但需要用到的內(nèi)容,怎樣將其變成自己掌握的內(nèi)容就很重要了,對(duì)知識(shí)的掌握應(yīng)該做到融會(huì)貫通。</p><p>
19、; 最后,我覺(jué)得接到一個(gè)任務(wù)不能立刻就下手編程序,應(yīng)該先理清楚思路,列出大概的框架,在需要注意的細(xì)節(jié)處做好標(biāo)記,寫(xiě)出應(yīng)注意的問(wèn)題;然后再編程。多翻看書(shū)籍,盡量簡(jiǎn)練的句子寫(xiě)出來(lái)。盲目的編寫(xiě)程序只會(huì)讓以后的工作很難展開(kāi),這些經(jīng)驗(yàn)必將對(duì)以后的學(xué)習(xí)起到重要的作用。</p><p><b> 6 參考文獻(xiàn)</b></p><p> [1] 譚浩強(qiáng),C程序設(shè)計(jì)題解與上機(jī)指導(dǎo)
20、(第二版),北京,清華大學(xué)出版社,2000年9月。</p><p> [2] 侯俊杰,深入淺出MFC,武漢,華中科技大學(xué)出版社,2001年1月。</p><p> [3] 丁有和,Visual C++實(shí)用教程,北京,電子工業(yè)出版社,2007 年1月。</p><p> [4] Thomas H.Cormen,算法導(dǎo)論,湖北,機(jī)械工業(yè)出版社,2006 年9月。
21、</p><p> [5] 《編程之美》小組,編程之美,北京,電子工業(yè)出版社,2009 年3月。</p><p> [6] 孫鑫,VC++深入詳解,北京,電子工業(yè)出版社,2000年9月。</p><p> [7] 陳維興,C++面向?qū)ο蟪绦蛟O(shè)計(jì)教程,北京,清華大學(xué)出版社,2009年6月。</p><p> [8] 杰夫瑞,Window
22、s 核心編程,北京,清華大學(xué)出版社,2008年9月。</p><p> [9] Jeff Prosise ,MFC Windows程序設(shè)計(jì),北京,清華大學(xué)出版社,2007 年5月。</p><p> [10] Paul McJones,編程的本質(zhì),湖北,機(jī)械工業(yè)出版社,2010 年3月。</p><p><b> 源代碼:</b>&l
23、t;/p><p> #include <stdio.h></p><p> #include <iostream></p><p> #include <iomanip></p><p> #include<windows.h></p><p> #define M
24、AXLength 10000</p><p> using namespace std;</p><p> int main()</p><p><b> {</b></p><p> cout<<endl<<endl;</p><p> cout<<
25、" ---------------------------------------------------------------------------"<<endl;</p><p> cout<<" ---------------------------------------------------------------------------
26、"<<endl;</p><p> cout<<" ---------------------------------------------------------------------------"<<endl;</p><p> cout<<" ********
27、********* Fibonacci 輸出系統(tǒng)*****************"<<endl<<endl; </p><p> cout<<"\n\t\t\t\t\t\t"<<"信息科學(xué)與技術(shù)學(xué)院";</p><p> cout<<"\n\t\t\t\t\t\t
28、"<<"計(jì)算機(jī)科學(xué)與技術(shù)專(zhuān)業(yè)";</p><p> cout<<"\n\t\t\t\t\t\t"<<"侯明· -- 學(xué)號(hào):2011508026"<<endl<<endl<<endl<<endl<<endl<<endl<&
29、lt;endl;</p><p><b> char a;</b></p><p> int b,i,n;</p><p> cout<<"進(jìn)入使用“數(shù)組求Fibonacci數(shù)列請(qǐng)按”1\n";</p><p><b> cin>>b;</b>&l
30、t;/p><p><b> switch(b)</b></p><p><b> {</b></p><p><b> case 1:</b></p><p> double f[MAXLength]; //定義一個(gè)數(shù)組</p><p&
31、gt;<b> again:</b></p><p> printf("輸入n(0≤n≤%d):",MAXLength);</p><p> scanf("%d",&n);</p><p> if (n>=MAXLength||n<0) //判斷n是否大于0,若是則繼
32、續(xù)進(jìn)行,若不是則返回!</p><p><b> {</b></p><p> printf("輸入的n太大或太?。?quot;);</p><p><b> return 1;</b></p><p><b> }</b></p><p&
33、gt; for (i=0;i<=n;i++) //循環(huán)結(jié)構(gòu)</p><p><b> {</b></p><p> if (i==0||i==1)f[i]=1;</p><p> else f[i]=f[i-1]+f[i-2];</p><p> printf("%-10.0f
34、 ",f[i]);</p><p> if(i%5==4)printf("\n");//每輸出5個(gè)輸出一個(gè)換行</p><p><b> }</b></p><p> printf("\n");</p><p> cout<<"繼續(xù)輸入請(qǐng)按y
35、,按 n 結(jié)束并跳轉(zhuǎn)至數(shù)據(jù)平移求Fibonacci數(shù)列\(zhòng)n"<<endl;</p><p><b> cin>>a;</b></p><p> if(a=='y'||a=='Y') goto again; //繼續(xù)或者退出</p><p> if(a=='n&
36、#39;||a=='N') goto fuc; // 如果輸入n直接調(diào)至fuc 使用數(shù)據(jù)平移求Fibonacci數(shù)列</p><p><b> break;</b></p><p><b> fuc:</b></p><p><b> while(1) </b>&l
37、t;/p><p> {long a,b,old1=1,old2=1;</p><p><b> int i,n;</b></p><p> Sleep(60*6);</p><p> cout<<endl<<"請(qǐng)輸入所需求的第N項(xiàng)。"<<endl;</p&
38、gt;<p><b> cin>>n;</b></p><p> if(n==0) {cout<<"出錯(cuò)了!"<<endl;break;} //輸入為0的話,就會(huì)結(jié)束循環(huán),并給出出錯(cuò)提示。</p><p> for(i=1;i<=n/2;i++)</p><p&g
39、t;<b> {</b></p><p> cout<<setw(12)<<old1<<setw(12)<<old2; //每個(gè)12字符輸出一個(gè)數(shù)。</p><p> if(i==n) cout<<endl<<"此時(shí)第n項(xiàng)為:"<<old2<<en
40、dl;</p><p> if(i%3==0) cout<<endl;//每行滿6項(xiàng)換行</p><p> old1=old1+old2;</p><p> old2=old2+old1;//實(shí)現(xiàn)數(shù)據(jù)平移</p><p><b> }</b></p><p><b&
溫馨提示
- 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 航空售票系統(tǒng)+c++課程設(shè)計(jì)
- c++酒店管理系統(tǒng)課程設(shè)計(jì)
- c++校園導(dǎo)游系統(tǒng)課程設(shè)計(jì)
- c++酒店管理系統(tǒng)課程設(shè)計(jì)
- c++課程設(shè)計(jì)——飛機(jī)訂票系統(tǒng)
- 銷(xiāo)售管理系統(tǒng)c++課程設(shè)計(jì)
- 《c++》課程設(shè)計(jì)倉(cāng)庫(kù)管理系統(tǒng)
- c++課程設(shè)計(jì)-學(xué)生管理系統(tǒng)
- c++學(xué)生管理系統(tǒng)課程設(shè)計(jì)
- c++課程設(shè)計(jì)--酒店管理系統(tǒng)
- c++課程設(shè)計(jì)報(bào)告
- c++課程設(shè)計(jì)ppt
- c++課程設(shè)計(jì)--基于c++的火車(chē)票管理系統(tǒng)
- c++課程設(shè)計(jì)--圖書(shū)管理系統(tǒng)
- 人事考勤管理系統(tǒng)c++課程設(shè)計(jì)
- c++課程設(shè)計(jì)-學(xué)生考勤管理系統(tǒng)
- 圖書(shū)管理系統(tǒng)c++課程設(shè)計(jì)
- c++課程設(shè)計(jì)學(xué)生通訊管理系統(tǒng)
- c++圖書(shū)管理系統(tǒng)課程設(shè)計(jì)
- c++課程設(shè)計(jì)報(bào)告-- 學(xué)籍管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論