版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、數(shù)據(jù)結(jié)構(gòu)實驗報告實驗名稱: 學生姓名: 班 級: 班內(nèi)序號: 學 號: 日 期: 實驗描述:使用鏈表實現(xiàn)下面各種排序算法,并進行比較。排序算法:1、插入排序2、冒泡排序3、快速排序4、簡單選擇排序5、其他1 程序分析 1.存儲結(jié)構(gòu):雙向鏈表 2.關(guān)鍵算法分析:a)插入排序:從有序數(shù)列和無序數(shù)列a2,a3,an開始進行排序; 處理第i個元素時(i=2,3,n),數(shù)列a1,a2,ai-1是已有序的,而數(shù)列ai,ai+1,an是無序的。用ai與ai-1,a i-2,a1進行比較,找出合適的位置將ai插入; 重復(fù)第二步,共進行n-i次插入處理,數(shù)列全部有序。b)冒泡排序: 1.比較相鄰的元素。如果第一
2、個比第二個大,就交換他們兩個。 2.對每一對相鄰元素作同樣的工作,從開始第一對到結(jié)尾的最后一對。在這一點,最后的元素應(yīng)該會是最大的數(shù)。 3.針對所有的元素重復(fù)以上的步驟,除了最后一個。 4.持續(xù)每次對越來越少的元素重復(fù)上面的步驟,直到?jīng)]有任何一對數(shù)字需要比較。c)快速排序:一趟快速排序的算法是: 1.設(shè)置兩個變量i、j,排序開始的時候:i=0,j=N-1; 2.以第一個數(shù)組元素作為關(guān)鍵數(shù)據(jù),賦值給key,即key=A0; 3.從j開始向前搜索,即由后開始向前搜索(j-),找到第一個小于key的值A(chǔ)j,將Aj和Ai互換; 4.從i開始向后搜索,即由前開始向后搜索(i+),找到第一個大于key的A
3、i,將Ai和Aj互換; 5.重復(fù)第3、4步,直到i=j; (3,4步中,沒找到符合條件的值,即3中Aj不小于key,4中Ai不大于key的時候改變j、i的值,使得j=j-1,i=i+1,直至找到為止。找到符合條件的值,進行交換的時候i, j指針位置不變。另外,i=j這一過程一定正好是i+或j-完成的時候,此時令循環(huán)結(jié)束)。d)簡單選擇排序:設(shè)所排序序列的記錄個數(shù)為n。i取1,2,n-1,從所有n-i+1個記錄(Ri,Ri+1,Rn)中找出排序碼最小的記錄,與第i個記錄交換。執(zhí)行n-1趟 后就完成了記錄序列的排序。 3.代碼詳細分析:#include<iostream>#includ
4、e<windows.h> using namespace std;struct Node /建立節(jié)點 int data;Node* last;Node* next;Node()last=NULL;next=NULL; class List /建立鏈表 private:Node* front;Node* rear;int length;public: List();List(int a,int n); void Insert(int x,Node* p); /在p后面插入節(jié)點 void Delete(Node* p); /刪除p節(jié)點 void Print(); /打印 void Se
5、qSort(); /插入排序 void BubSort(); /冒泡排序 void QuiSort(); /快速排序 void Qui(Node* first,Node* end,int* c); /快速排序的遞歸函數(shù) void SelSort(); /簡單選擇排序 ;List:List(int a,int n) /構(gòu)造函數(shù) front=new Node;length=n;rear=front;int i;Node* s; for(i=0;i<n;i+)s=new Node;s->data=ai;rear->next=s;s->last=rear;rear=s;void
6、 List:Insert(int x,Node* p) /插入函數(shù) Node* s=new Node;s->data=x;s->last=p->last;p->last->next=s;p->last=s;s->next=p; void List:Print() /打印函數(shù) Node* p=front->next;while(p!=NULL)cout<<p->data<<" "p=p->next;cout<<endl;void List:Delete(Node* p) /刪除函數(shù)
7、 Node* De=p;if(p=rear)rear=p->last;p->last->next=NULL;delete De;else p->last->next=p->next; p->next->last=p->last; delete De;void List:SeqSort() /插入排序 LARGE_INTEGER large_interger; double dff; _int64 c1, c2; QueryPerformanceFrequency(&large_interger); dff = large_inter
8、ger.QuadPart; QueryPerformanceCounter(&large_interger); c1 = large_interger.QuadPart;int ccom=0; int cmove=0;Node* p=front->next->next;Node* q;Node* De;bool ifdelete;while(p!=NULL)ifdelete=0;q=front->next;while(q!=p) ccom+;if(q->data>=p->data)De=p;Insert(p->data,q);ifdelete=
9、1;break;q=q->next;p=p->next;if(ifdelete=1)Delete(De);QueryPerformanceCounter(&large_interger); c2 = large_interger.QuadPart; cout<<"SeqSort:"Print();cout<<"比較次數(shù):"<<ccom<<endl;cout<<"移動次數(shù):"<<cmove<<endl;cout<<&quo
10、t;用時:"<<(c2 - c1) * 1000*1000/dff<<"微秒"<<endl; cout<<endl;void List:BubSort() /冒泡排序 LARGE_INTEGER large_interger; double dff; _int64 c1, c2; QueryPerformanceFrequency(&large_interger); dff = large_interger.QuadPart; QueryPerformanceCounter(&large_interg
11、er); c1 = large_interger.QuadPart; int ccom=0; int cmove=0;Node* p;Node* q=rear;int temp;int j;for(j=0;j<length-1;j+) p=front->next; while(p!=q) ccom+; if(p->data>p->next->data) temp=p->next->data; p->next->data=p->data; p->data=temp; cmove+=3; p=p->next; q=q-&
12、gt;last; QueryPerformanceCounter(&large_interger); c2 = large_interger.QuadPart; cout<<"BubSort:" Print();cout<<"比較次數(shù):"<<ccom<<endl;cout<<"移動次數(shù):"<<cmove<<endl;cout<<"用時:"<<(c2 - c1) * 1000*1000/dff<&
13、lt;"微秒"<<endl; cout<<endl;void List:Qui(Node* first,Node* end,int* c) /快速排序(有參數(shù)) Node* p1=first;Node* p2=end;int pivot=p1->data;while(p1!=p2) while(p1!=p2&p2->data>=pivot)p2=p2->last;c0+;c0+;p1->data=p2->data;c1+;while(p1!=p2&p1->data<=pivot)p1=p
14、1->next;c0+;c0+;p2->data=p1->data;c1+;p1->data=pivot;if(p1->last!=first&p1!=first)Qui(first,p1->last,c);if(p2->next!=end&&p2!=end)Qui(p1->next,end,c); void List:QuiSort() /快速排序(轉(zhuǎn)化為無參)LARGE_INTEGER large_interger; double dff; _int64 c1, c2; QueryPerformanceFrequenc
15、y(&large_interger); dff = large_interger.QuadPart; QueryPerformanceCounter(&large_interger); c1 = large_interger.QuadPart; int count2=0;Qui(front->next,rear,count);QueryPerformanceCounter(&large_interger); c2 = large_interger.QuadPart; cout<<"QuiSort:"Print();cout<&
16、lt;"比較次數(shù):"<<count0<<endl;cout<<"移動次數(shù):"<<count1<<endl;cout<<"用時:"<<(c2 - c1) * 1000*1000/dff<<"微秒"<<endl; cout<<endl;void List:SelSort() /簡單選擇排序 LARGE_INTEGER large_interger; double dff; _int64 c1, c2;
17、 QueryPerformanceFrequency(&large_interger); dff = large_interger.QuadPart; QueryPerformanceCounter(&large_interger); c1 = large_interger.QuadPart; int ccom=0; int cmove=0;Node* p=front->next;Node* q;int temp;while(p!=rear)q=rear;while(q!=p)ccom+;if(q->data<p->data)temp=q->dat
18、a;q->data=p->data;p->data=temp; cmove+=3;q=q->last;p=p->next;QueryPerformanceCounter(&large_interger); c2 = large_interger.QuadPart; cout<<"SelSort:" Print();cout<<"比較次數(shù):"<<ccom<<endl;cout<<"移動次數(shù):"<<cmove<<end
19、l;cout<<"用時:"<<(c2 - c1) * 1000*1000/dff<<"微秒"<<endl; cout<<endl;main()const int n=5;int an;cout<<"輸入一組"<<n<<"個數(shù)據(jù):"<<endl; int i;for(i=0;i<n;i+)cin>>ai;List L1(a,n);List L2(a,n);List L3(a,n);List L4(a,n); int Menu;while(1) cout<<"Menu:"<<endl; cout<<"1.插入排序"<<endl; cout<<"2.冒泡排序"&l
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025便利店商品采購與配送合同范本3篇
- 二零二五年度家居裝飾材料區(qū)域代理采購合同3篇
- 2025年度10架AC311A直升機購銷與地面服務(wù)保障合同3篇
- 二零二四年度三方貸款資金管理合同3篇
- 二零二五版高端裝備制造工廠生產(chǎn)承包合同書模板3篇
- 年度智慧停車戰(zhàn)略市場規(guī)劃報告
- 2025年蔬菜大棚農(nóng)業(yè)科技研發(fā)與創(chuàng)新合作合同2篇
- 年度丙二酮戰(zhàn)略市場規(guī)劃報告
- 二零二五版?zhèn)€人短期租房合同補充協(xié)議2篇
- 2024-2025學年高中歷史第8單元20世紀下半葉世界的新變化第21課世界殖民體系的瓦解與新興國家的發(fā)展課時作業(yè)含解析新人教版必修中外歷史綱要下
- 第12講 語態(tài)一般現(xiàn)在時、一般過去時、一般將來時(原卷版)
- 2024年采購員年終總結(jié)
- 2024年新疆區(qū)公務(wù)員錄用考試《行測》試題及答案解析
- 肺動脈高壓的護理查房課件
- 2025屆北京巿通州區(qū)英語高三上期末綜合測試試題含解析
- 公婆贈予兒媳婦的房產(chǎn)協(xié)議書(2篇)
- 煤炭行業(yè)智能化煤炭篩分與洗選方案
- 2024年機修鉗工(初級)考試題庫附答案
- Unit 5 同步練習人教版2024七年級英語上冊
- 矽塵對神經(jīng)系統(tǒng)的影響研究
- 分潤模式合同模板
評論
0/150
提交評論