《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告_第1頁(yè)
《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告_第2頁(yè)
《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告_第3頁(yè)
《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告_第4頁(yè)
《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告_第5頁(yè)
已閱讀5頁(yè),還剩17頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、.課程設(shè)計(jì)報(bào)告-數(shù)據(jù)結(jié)構(gòu)學(xué)院:軟件學(xué)院班級(jí):11級(jí)二班學(xué)號(hào):54110211姓名:劉海鯨輔導(dǎo)老師:劉亞波老師數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告姓名:劉海鯨學(xué)號(hào):54110211實(shí)驗(yàn)室:座位號(hào):提交日期:2013.3.13成績(jī):指導(dǎo)教師:劉亞波問(wèn)題解析(對(duì)問(wèn)題的分析、解題思路與解題方法):實(shí)驗(yàn)?zāi)康臑槭刮覀儗W(xué)習(xí)完數(shù)據(jù)結(jié)構(gòu)課程后,全面深入理解數(shù)據(jù)結(jié)構(gòu)知識(shí),掌握應(yīng)用技巧,提高應(yīng)用與分析能力,并培養(yǎng)學(xué)生綜合運(yùn)用所學(xué)理論知識(shí)求解問(wèn)題的能力和協(xié)作精神。解題思路(分析):題目要求獨(dú)立編寫(xiě)程序,完成對(duì)起泡排序,直接插入排序,簡(jiǎn)單選擇排序,快速排序,希爾排序,堆排序6種內(nèi)排序算法的比較,并且使用至少5組不同的輸入數(shù)據(jù)(記錄個(gè)數(shù)

2、不小于1000個(gè),其中包括完全正序,完全逆序和無(wú)序情況)進(jìn)行排序,比較各組記錄與各種排序方法在關(guān)鍵字比較次數(shù)和關(guān)鍵字移動(dòng)次數(shù)這兩個(gè)指標(biāo)上的差異。因此只需對(duì)文件進(jìn)行排序并計(jì)算出兩項(xiàng)指標(biāo)針對(duì)某一組特定數(shù)據(jù)在不同排序方法中的值,既可以完成題目要求。編寫(xiě)正確的排序算法,使用程序讀取不同文件,并定義變量,記錄排序過(guò)程中兩項(xiàng)指標(biāo)的值,就是本題的解題思路。解題方法:使用Code:blocks作為本次實(shí)驗(yàn)的開(kāi)發(fā)工具,使用C+完成程序。首先使用數(shù)據(jù)產(chǎn)生程序來(lái)產(chǎn)生所需的5個(gè)數(shù)據(jù)文件,使用了C+中cstdlib文件中的rand()函數(shù)和srand()函數(shù)共同產(chǎn)生3組偽隨機(jī)數(shù);在另一個(gè)工程中創(chuàng)建了data.h與con

3、trol.h兩個(gè)頭文件和main.cpp源文件,其中data.h定義了數(shù)據(jù)類型(模板類),包括主要的排序函數(shù)和數(shù)據(jù)成員,control.h定義了控制類,來(lái)完成界面控制,數(shù)據(jù)文件讀取和排序功能的實(shí)現(xiàn),main.cpp是對(duì)控制類對(duì)象的控制函數(shù)conmian()的調(diào)用來(lái)完成整個(gè)程序。最后運(yùn)行程序來(lái)完成對(duì)比較指標(biāo)的統(tǒng)計(jì)并進(jìn)行分析,對(duì)得出結(jié)果進(jìn)行解釋。任務(wù)分工:本實(shí)驗(yàn)由本人獨(dú)立完成。進(jìn)度安排:為第一次實(shí)驗(yàn)課將6個(gè)內(nèi)排序算法完成并調(diào)試成功,周末之前完成界面控制并對(duì)排序結(jié)果進(jìn)行分析,第二次實(shí)驗(yàn)之前完成課程設(shè)計(jì)報(bào)告,第二次試驗(yàn)對(duì)程序結(jié)果進(jìn)行最后檢查并提交實(shí)驗(yàn)報(bào)告。數(shù)據(jù)結(jié)構(gòu)選擇(包括改進(jìn)或給出):使用數(shù)組作為本

4、實(shí)驗(yàn)基本的數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)類中包含有數(shù)組的頭指針head,在初始化時(shí)動(dòng)態(tài)申請(qǐng)數(shù)組空間,此外還有count(整型)用于記錄數(shù)組個(gè)數(shù),同時(shí)可以對(duì)數(shù)組進(jìn)行6種內(nèi)排序及顯示數(shù)組元素的操作。算法設(shè)計(jì):借助課本與網(wǎng)絡(luò),使用C+編寫(xiě)算法,詳細(xì)請(qǐng)看后面程序清單。編程與程序清單:1./頭文件data.h2./文件數(shù)據(jù)類Data定義3. /起泡排序(升序)4. /直接插入排序(升序)5. /簡(jiǎn)單選擇排序(升序)6. /快速排序(升序)7./快速排序的遞歸函數(shù)8./希爾排序 (升序)9./插入排序(升序)10. /堆排序(升序)11./控制類12. /功能選擇13./主函數(shù)1./頭文件data.h 1./頭文件dat

5、a.h#ifndef DATA_H_INCLUDED#define DATA_H_INCLUDED#include<ctime>#include<iostream>using namespace std;2./文件數(shù)據(jù)類Data定義template<class T>class Data private: T *head; /數(shù)據(jù)數(shù)組指針,用于動(dòng)態(tài)申請(qǐng)數(shù)組空間 int count; /數(shù)組大小 public: /構(gòu)造函數(shù),使指針為空 Data()head=NULL; /用已有數(shù)組構(gòu)造數(shù)組元素,當(dāng)前程序使用該函數(shù)來(lái)構(gòu)造數(shù)據(jù)元素 void copy(T *h,in

6、t c=1000) if(head!=NULL) delete head; head=h;count=c; head=new Tcount; for(int i=0;i<count;i+) headi=hi; /手動(dòng)輸入各元素,當(dāng)前程序未使用,調(diào)試程序時(shí)使用! void set() if(head!=NULL) delete head; cout<<"請(qǐng)輸入數(shù)據(jù)個(gè)數(shù):"<<endl; cin>>count; head=new Tcount; cout<<"請(qǐng)輸入數(shù)據(jù):"<<endl; fo

7、r(int i=0;i<count;i+) cin>>headi; /析構(gòu)函數(shù),回收空間 Data()delete head;3. /起泡排序(升序) void bSort() if(isEmpty()cout<<" 文件中無(wú)記錄,無(wú)法排序!"<<endl;return; int compareTime=0; /關(guān)鍵詞比較次數(shù) int moveTime=0; /關(guān)鍵詞移動(dòng)次數(shù) int bound=count; int start,finish; /記錄程序運(yùn)行時(shí)間 T temp; cout<<" 正在排序.&q

8、uot;<<endl; start=clock(); /記錄初始時(shí)間 /算法主體 while(bound!=0) int t=0; for(int i=0;i<bound-1;i+) compareTime+; if(headi>headi+1) temp=headi; headi=headi+1; headi+1=temp; t=i+1; moveTime+=3; /記錄交換一次移動(dòng)次數(shù)加3 bound=t; finish=clock(); cout<<" >>排序后結(jié)果為:"<<endl; display();

9、 /輸出排序后序列 cout<<endl<<" *-"<<endl <<" *關(guān)鍵詞比較次數(shù):"<<compareTime<<endl <<" *記錄移動(dòng)次數(shù):"<<moveTime<<endl <<" *排序執(zhí)行時(shí)間:"<<finish-start<<"ms"<<endl <<" *-"<<end

10、l<<endl; 4. /直接插入排序(升序) void iSort() if(isEmpty()cout<<" 文件中無(wú)記錄,無(wú)法排序!"<<endl; int compareTime=0; int moveTime=0; long start,finish; T temp; cout<<" 正在排序."<<endl; start=clock(); for(int i=1;i<count;i+) int j; j=i-1; temp=headi; moveTime+; /無(wú)記錄交換,僅有

11、向輔存中移動(dòng),故移動(dòng)次數(shù)加1 while(j>=0&&headj>temp) compareTime+; headj+1=headj; moveTime+; /記錄向后移一位,移動(dòng)次數(shù)加1 j-; compareTime+; /跳出循環(huán)后比較次數(shù)要再加1 headj+1=temp; moveTime+; finish=clock(); cout<<" >>排序后結(jié)果為:"<<endl; display(); cout<<endl<<" *-"<<endl

12、<<" *關(guān)鍵詞比較次數(shù):"<<compareTime<<endl <<" *記錄移動(dòng)次數(shù):"<<moveTime<<endl <<" *排序執(zhí)行時(shí)間:"<<(finish-start)<<"ms"<<endl <<" *-"<<endl<<endl; 5. /簡(jiǎn)單選擇排序(升序) void sSort() if(isEmpty()cout&

13、lt;<" 文件中無(wú)記錄,無(wú)法排序!"<<endl; int compareTime=0; int moveTime=0; long start,finish; T temp; cout<<" 正在排序."<<endl; start=clock(); for(int i=0;i<count-1;i+) int j=i; for(int k=i+1;k<count;k+) compareTime+; if(headj>headk) j=k; /標(biāo)記當(dāng)前最大的記錄下標(biāo) if(i!=j) temp=h

14、eadi; headi=headj; headj=temp; moveTime+=3; finish=clock(); cout<<" >>排序后結(jié)果為:"<<endl; display(); cout<<endl<<" *-"<<endl <<" *關(guān)鍵詞比較次數(shù):"<<compareTime<<endl <<" *記錄移動(dòng)次數(shù):"<<moveTime<<endl <

15、;<" *排序執(zhí)行時(shí)間:"<<(finish-start)<<"ms"<<endl <<" *-"<<endl<<endl; 6. /快速排序(升序) void qqSort() if(isEmpty()cout<<" 文件中無(wú)記錄,無(wú)法排序!"<<endl; long start,finish; int times2=0,0; /要調(diào)用函數(shù),故使用數(shù)組來(lái)記錄關(guān)鍵詞的比較次數(shù)和移動(dòng)次數(shù),直接進(jìn)行計(jì)數(shù) start=c

16、lock(); cout<<" 正在排序."<<endl; qSort(head,0,count,times); /一趟快速排序函數(shù) finish=clock(); cout<<" >>排序后結(jié)果為:"<<endl; display(); cout<<endl<<" *-"<<endl <<" *關(guān)鍵詞比較次數(shù):"<<times0<<endl <<" *記錄移動(dòng)次

17、數(shù):"<<times1<<endl <<" *排序執(zhí)行時(shí)間:"<<(finish-start)<<"ms"<<endl <<" *-"<<endl<<endl; 7./快速排序的遞歸函數(shù) void qSort(T *head,int m,int n,int *times) int i=m,j=n; T temp=headm,t=m; if(m<n) /遞歸出口(m>=n) while(i<j) i=i

18、+1; while(headi<temp&&i!=n)times0+;i+; j=j-1; while(headj>temp&&j!=m)times0+;j-; if(i<j) t=headi; headi=headj; headj=t; times1+=3; if(m!=j) t=headm; headm=headj; headj=t; times1+=3; qSort(head,m,j,times); qSort(head,j+1,n,times); 8./希爾排序 (升序) void shell() if(isEmpty()cout<

19、;<" 文件中無(wú)記錄,無(wú)法排序!"<<endl; int times2=0,0; int seq8=701,301,132,57,23,10,4,1; /依據(jù)課本得到希爾排序最優(yōu)的增量遞減序列 long start,finish; cout<<" 正在排序."<<endl; start=clock(); int n; for(int i=0;i<8;i+) n=seqi; insert(n,times); /調(diào)用插入排序算法對(duì)同組數(shù)據(jù)進(jìn)行排序 finish=clock(); cout<<&quo

20、t; >>排序后結(jié)果為:"<<endl; display(); cout<<endl<<" *-"<<endl <<" *關(guān)鍵詞比較次數(shù):"<<times0<<endl <<" *記錄移動(dòng)次數(shù):"<<times1<<endl <<" *排序執(zhí)行時(shí)間:"<<(finish-start)<<"ms"<<endl

21、<<" *-"<<endl<<endl; 9./插入排序(被希爾排序shell函數(shù)調(diào)用) void insert(int n,int * times) /增量為n帶來(lái)一系列程序的改動(dòng) for(int k=0;k+n<count;k+) T temp; for(int i=k+n;i<count;i+=n) int j; j=i-n; temp=headi; times1+; while(j>=k&&headj>temp) times0+; headj+n=headj; times1+; j-=n;

22、times0+; headj+n=temp; times1+; 10. /堆排序(升序) void hSort() /堆為完全二叉樹(shù),故可用數(shù)組構(gòu)造堆,且不會(huì)造成空間的浪費(fèi) if(isEmpty()cout<<" 文件中無(wú)記錄,無(wú)法排序!"<<endl; int times2=0,0; T temp; long start,finish; cout<<" 正在排序."<<endl; start=clock(); /初始建堆 for(int i=count/2;i>0;i-) restore(i,cou

23、nt,times); /排序及重建堆 for(int i=count;i>1;i-) temp=head0; head0=headi-1; headi-1=temp; times1+=3; restore(1,i-1,times); finish=clock(); cout<<" >>排序后結(jié)果為:"<<endl; display(); cout<<endl<<" *-"<<endl <<" *關(guān)鍵詞比較次數(shù):"<<times0<

24、;<endl <<" *記錄移動(dòng)次數(shù):"<<times1<<endl <<" *排序執(zhí)行時(shí)間:"<<(finish-start)<<"ms"<<endl <<" *-"<<endl<<endl; /重建堆算法(被堆排序hSort函數(shù)調(diào)用) void restore(int a,int b,int * times) int mark,j=a; T temp; while(j<=b/2)

25、if(2*j<b&&head2*j-1<head2*j) mark=2*j; times0+; else mark=2*j-1; times0+; if(headmark>headj-1) temp=headmark; headmark=headj-1; headj-1=temp; j=mark+1; times0+; times1+=3; else j=b; /人為改變j的值,跳出循環(huán),退出程序 times0+; /輸出記錄序列(升序) void display() for(int i=0;i<count;i+) cout<<headi&l

26、t;<" " cout<<endl; /判斷數(shù)據(jù)是否為空 bool isEmpty()constreturn head=NULL; /獲得頭指針,本程序未使用! T *getHead()return head; /獲得數(shù)組元素個(gè)數(shù),本程序未使用! int getCount ()constreturn count;#endif / DATA_H_INCLUDED/頭文件control.h#ifndef CONTROL_H_INCLUDED#define CONTROL_H_INCLUDED#include"data.h"#include&

27、lt;iostream>#include<sstream> /含有istringstream類#include<fstream>using namespace std;11./控制類,進(jìn)行界面管理,記錄文件讀取,調(diào)用排序函數(shù)等操作class Control public: void conmain() /控制函數(shù) cout<<"#" <<"#【數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)(一):內(nèi)排序算法比較】#" <<"#" cout<<"#使用說(shuō)明:運(yùn)行程序,請(qǐng)輸入數(shù)據(jù)文

28、件名(a.txt,b.txt,c.txt均為無(wú)序數(shù)據(jù),d.txt為完#" <<"#全正序數(shù)據(jù),e.txt為完全逆序文件,均存放在當(dāng)前目錄下),之后請(qǐng)按照用戶個(gè)人需求 #" <<"#選擇相應(yīng)功能! #" <<"#" <<" #"<<endl <<" #>>功能列表 #"<<endl <<" #"<<endl <<" # 1.起泡

29、排序 (升序) #"<<endl <<" # 2.直接插入排序(升序) #"<<endl <<" # 3.簡(jiǎn)單選擇排序 (升序) #"<<endl <<" # 4.快速排序(升序) #"<<endl <<" # 5.希爾排序(升序) #"<<endl <<" # 6.堆排序(升序) #"<<endl <<" # 0.退出 #"

30、;<<endl <<" #"<<endl;/定義選擇變量及輔助變量int opt1,a,i=0;/數(shù)組存儲(chǔ)數(shù)據(jù)int data1000;/定義Data類對(duì)象Data<int> temp;/文件名string file; /讀取文件,從輸入的文件名中讀取數(shù)據(jù),a.txt,b.txt,c.txt為隨機(jī)數(shù)據(jù),e.txt為正序,e.txt為逆序cout<<endl<<" >>請(qǐng)輸入目標(biāo)數(shù)據(jù)文件:" cin>>file; ifstream in(file.c_str()

31、; /string類轉(zhuǎn)換為字符串且在末尾加'0' for(string s;getline(in,s);) /讀取文件,讀取整行,使用istringstream類讀出數(shù)字(可自動(dòng)忽略數(shù)字間的空格) for(istringstream sin(s);sin>>a;); datai+=a; 12. /功能選擇cout<<endl<<" >>請(qǐng)選擇功能(輸入對(duì)應(yīng)功能的序號(hào)):"cin>>opt1;while(opt1)switch(opt1) /調(diào)用起泡排序函數(shù)case 1:temp.copy(data)

32、;temp.bSort();break; /調(diào)用直接插入排序函數(shù)case 2:temp.copy(data);temp.iSort();break; /調(diào)用簡(jiǎn)單選擇排序函數(shù)case 3:temp.copy(data);temp.sSort();break; /調(diào)用快速排序函數(shù) case 4:temp.copy(data);temp.qqSort();break; /調(diào)用Shell排序函數(shù) case 5:temp.copy(data);temp.shell();break; /調(diào)用堆排序函數(shù) case 6:temp.copy(data);temp.hSort();break; <<&

33、quot; |<您的輸入有誤,請(qǐng)?jiān)俅屋斎耄?gt;|"<<endl <<" -"<<endl; cout<<" #"<<endl <<" #>>功能列表 #"<<endl <<" #"<<endl <<" # 1.起泡排序 (升序) #"<<endl <<" # 2.直接插入排序(升序) #"<<

34、;endl <<" # 3.簡(jiǎn)單選擇排序 (升序) #"<<endl <<" # 4.快速排序(升序) #"<<endl <<" # 5.希爾排序(升序) #"<<endl <<" # 6.堆排序(升序) #"<<endl <<" # 0.退出 #"<<endl <<" #"<<endl;cout<<endl<<

35、;" >>請(qǐng)選擇功能(輸入對(duì)應(yīng)功能的序號(hào)):"cin>>opt1;cout<<"#"<<"#"<<"#"<<endl; ;#endif / CONTROL_H_INCLUDED/源文件main.cpp#include"data.h"#include"control.h"#include<iostream>using namespace std;12./主函數(shù)int main() Control

36、 a; /控制類Control類對(duì)象 a.conmain(); /控制函數(shù) return 0;測(cè)試方法:使用排序程序前,先使用數(shù)據(jù)產(chǎn)生程序generator產(chǎn)生所需數(shù)據(jù)(整型,1000個(gè)記錄),包括3組無(wú)序數(shù)據(jù)(用rand()與srand()函數(shù)產(chǎn)生),一組完全正序數(shù)據(jù)和一組完全逆序數(shù)據(jù),并分別存儲(chǔ)于5個(gè)不同的文本文件中。在排序程序中依次讀取5個(gè)數(shù)據(jù)文件并按照程序的提示對(duì)數(shù)據(jù)進(jìn)行排序,觀測(cè)輸出的排序序列并對(duì)關(guān)鍵詞比較次數(shù)和關(guān)鍵詞移動(dòng)次數(shù)進(jìn)行分析。測(cè)試數(shù)據(jù):由數(shù)據(jù)產(chǎn)生程序generator產(chǎn)生,存儲(chǔ)于文件由數(shù)據(jù)產(chǎn)生程序generator產(chǎn)生,存儲(chǔ)于文件a.txt,b.txt,c.txt,d.tx

37、t,e.txt(前三個(gè)為無(wú)序記錄文件,第四個(gè)為完全正序文件,第五個(gè)為完全逆序文件)中,記錄為整型數(shù)據(jù), 規(guī)模為1000數(shù)量級(jí)。測(cè)試結(jié)果:起泡排序數(shù)據(jù)組別比較次數(shù)/次移動(dòng)次數(shù)/次排序時(shí)間/ms理論值(最好,最壞,平均)O(n),O(n2),O(n2)0,O(n2),O(n2)-a49729676015212b49713975650716c49559674349912d99901e499500149850014直接插入排序數(shù)據(jù)組別比較次數(shù)/次移動(dòng)次數(shù)/次排序時(shí)間/ms理論值(最好,最壞,平均)O(n),O(n2),O(n2)O(n),O(n2),O(n2)-a2543832553825b25316

38、82541676c2488322498315d99919981e50049950149811簡(jiǎn)單選擇排序數(shù)據(jù)組別比較次數(shù)/次移動(dòng)次數(shù)/次排序時(shí)間/ms理論值(最好,最壞,平均)O(n2),O(n2),O(n2)0,O(n),O(n)-a49950029856b49950029766c49950029736d49950007e49950015009快速排序數(shù)據(jù)組別比較次數(shù)/次移動(dòng)次數(shù)/次排序時(shí)間/ms理論值(最好,最壞,平均)O(n·log2n),O(n·log2n),O(n·log2n)0,O(n·log2n),O(n·log2n)-a834182953b663983764c759382232d49950005e49950015006Shell排序數(shù)據(jù)組別比較次數(shù)/次移動(dòng)次數(shù)/次排序時(shí)間/ms理論值(最好,最壞,平均)O(n·(log2n)2)O(n·(log2n)2)-a714181142199923b714136142195422c714210142202821d707818141563622e710908141872621堆

溫馨提示

  • 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ù)網(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論