北郵數(shù)據(jù)結(jié)構(gòu)實驗四鏈表排序_第1頁
北郵數(shù)據(jù)結(jié)構(gòu)實驗四鏈表排序_第2頁
北郵數(shù)據(jù)結(jié)構(gòu)實驗四鏈表排序_第3頁
北郵數(shù)據(jù)結(jié)構(gòu)實驗四鏈表排序_第4頁
北郵數(shù)據(jù)結(jié)構(gòu)實驗四鏈表排序_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、數(shù)據(jù)結(jié)構(gòu)實驗報告實驗名稱: 學(xué)生姓名: 班 級: 班內(nèi)序號: 學(xué) 號: 日 期: 實驗描述:使用鏈表實現(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)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論