北郵數(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)實驗報告實驗名稱: 學生姓名: 班 級: 班內(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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論