版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、.算法設(shè)計與分析實驗報告實驗1 分治算法姓名 學(xué)號 班級 實驗日期 2015.1.13 實驗地點 一、實驗?zāi)康?、掌握分治算法的設(shè)計思想與分析方法;2、掌握歸并排序、快速排序等高效排序算法。二、實驗環(huán)境1、硬件環(huán)境CPU:酷睿i5內(nèi)存:4GB硬盤:1TB2、軟件環(huán)境操作系統(tǒng):win10編程環(huán)境:Dev-C+編程語言:C語言三、實驗內(nèi)容1、編寫程序,實現(xiàn)歸并排序算法。(1)歸并排序算法歸并排序是建立在歸并操作上的一種有效的排序算法,該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。(
2、2)歸并排序算法分析時間復(fù)雜度:O(nlogn)空間復(fù)雜度O(nlogn)(3)編程要求l 待排序數(shù)組長度至少為16,數(shù)組中可以有相同元素;l 按遞增排序。(4)程序代碼(含注釋)/歸并排序算法實現(xiàn) #include <stdio.h>#include <malloc.h>#define MAXE 50/線性表中最多元素個數(shù)typedef int KeyType;typedef char InfoType10;typedef struct /記錄類型KeyType key; /關(guān)鍵字項 InfoType data; /其他數(shù)據(jù)項,類型為InfoType RecType;
3、void Merge(RecType R,int low,int mid,int high) /將兩個有序表Rlow.mid和Rmid+1.high歸并為一個有序表Rlow.high中RecType *R1;int i=low,j=mid+1,k=0; /k是R1的下標(biāo),i、j分別為第1、2段的下標(biāo)R1=(RecType *)malloc(high-low+1)*sizeof(RecType); /動態(tài)分配空間while (i<=mid && j<=high) /在第1段和第2段均未掃描完時循環(huán)if (Ri.key<=Rj.key) /將第1段中的記錄放入R1
4、中R1k=Ri;i+;k+; else /將第2段中的記錄放入R1中R1k=Rj;j+;k+; while (i<=mid) /將第1段余下部分復(fù)制到R1 R1k=Ri;i+;k+; while (j<=high) /將第2段余下部分復(fù)制到R1R1k=Rj;j+;k+; for (k=0,i=low;i<=high;k+,i+) /將R1復(fù)制回R中 Ri=R1k; void MergePass(RecType R,int length,int n)/實現(xiàn)一趟歸并int i;for (i=0;i+2*length-1<n;i=i+2*length) /歸并length長的
5、兩相鄰子表Merge(R,i,i+length-1,i+2*length-1); if (i+length-1<n) /余下兩個子表,后者長度小于lengthMerge(R,i,i+length-1,n-1); /歸并這兩個子表void MergeSort(RecType R,int n) /二路歸并排序算法int length,k,i=1;/i用于累計歸并的趟數(shù)for (length=1;length<n;length=2*length)MergePass(R,length,n);printf(" 第%d趟歸并 ",i+);/輸出每一趟的排序結(jié)果for (k=
6、0;k<n;k+)printf("%4d",Rk.key);printf("n");int main()int i,k,n;RecType RMAXE;printf("請輸入元素個數(shù)n:n");scanf("%d",&n);printf("請輸入%d個元素:n",n);for (i=0;i<n;i+)scanf("%d",&Ri.key);printf("n");MergeSort(R,n);/執(zhí)行排序函數(shù)printf(&quo
7、t;歸并排序結(jié)果:n");printf(" ");for (k=0;k<n;k+)printf("%5d",Rk.key);printf("nn");return 0;(5)程序輸出2、編寫程序,實現(xiàn)快速排序算法。(1)快速排序算法基本思想是:通過一趟排序?qū)⒁判虻臄?shù)據(jù)分割成獨立的兩部分,其中一部分的所有數(shù)據(jù)都比另外一部分的所有數(shù)據(jù)都要小,然后再按此方法對這兩部分?jǐn)?shù)據(jù)分別進(jìn)行快速排序,整個排序過程可以遞歸進(jìn)行,以此達(dá)到整個數(shù)據(jù)變成有序序列。(2)快速排序算法分析時間復(fù)雜度:O(nlogn)空間復(fù)雜度:O(nlogn)(
8、3)編程要求l 待排序數(shù)組長度至少為16,數(shù)組中可以有相同元素;l 按遞增排序。(4)程序代碼(含注釋)/快速排序算法實現(xiàn) #include <stdio.h>#define MAXE 50/線性表中最多元素個數(shù)typedef int KeyType;typedef char InfoType10;typedef struct /記錄類型KeyType key; /關(guān)鍵字項 InfoType data; /其他數(shù)據(jù)項,類型為InfoType RecType;void QuickSort(RecType R,int s,int t) /對Rs至Rt的元素進(jìn)行快速排序int i=s,j
9、=t,k;RecType temp;if (s<t) /區(qū)間內(nèi)至少存在一個元素的情況temp=Rs; /用區(qū)間的第1個記錄作為基準(zhǔn) while (i!=j) /從區(qū)間兩端交替向中間掃描,直至i=j為止while (j>i && Rj.key>temp.key) j-; /從右向左掃描,找第1個關(guān)鍵字小于temp.key的Rj if (i<j) /表示找到這樣的Rj,Ri、Rj交換Ri=Rj;i+; while (i<j && Ri.key<temp.key) i+;/從左向右掃描,找第1個關(guān)鍵字大于temp.key的記錄Ri
10、if (i<j) /表示找到這樣的Ri,Ri、Rj交換Rj=Ri;j-; Ri=temp; QuickSort(R,s,i-1); /對左區(qū)間遞歸排序QuickSort(R,i+1,t); /對右區(qū)間遞歸排序int main()int i,k,n;RecType RMAXE;printf("請輸入元素個數(shù)n:n");scanf("%d",&n);printf("請輸入%d個元素:n",n);for (i=0;i<n;i+)scanf("%d",&Ri.key);printf("n");QuickSort(R,0,n-1);/執(zhí)行排序函數(shù)printf("快速排序結(jié)果:n");printf(" ");for (k=0;k<n;k+)printf("%5d",Rk.key);printf("nn");return 0;(5)程序輸出四、實驗總結(jié)(心得體會、需要
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版辦公室裝修與辦公環(huán)境評估咨詢合同3篇
- 二零二五年度防汛應(yīng)急物資采購及質(zhì)量檢測合同3篇
- 《職業(yè)教育無人機(jī)應(yīng)用技術(shù) 第3部分 教學(xué)設(shè)備》 (T-AOPA 0030-2022)
- 二零二五年房地產(chǎn)抵押擔(dān)保中小企業(yè)借款合同2篇
- 二零二五年度藥品研發(fā)合作合同3篇
- 二零二五版建筑工程尾款結(jié)算快速結(jié)算合同3篇
- 關(guān)于公司職能組織機(jī)構(gòu)設(shè)置和職責(zé)分工的通知
- 二零二五年餐飲餐具進(jìn)口與國內(nèi)采購合同3篇
- 二零二五年度酒水行業(yè)連鎖經(jīng)營與品牌管理合同3篇
- 二零二五版2025年在線教育平臺服務(wù)合同范本2篇
- 鋼構(gòu)樓板合同范例
- 2024-2025學(xué)年人教版(2024)信息技術(shù)四年級上冊 第11課 嘀嘀嗒嗒的秘密 說課稿
- 2024中考物理真題匯編:電與磁(含解析)
- 物流管理概論 課件全套 王皓 第1-10章 物流與物流管理的基礎(chǔ)知識 - 物流系統(tǒng)
- 蘇教版六年級上冊分?jǐn)?shù)四則混合運算100題帶答案
- 2024年考研英語(一)真題及參考答案
- 醫(yī)療組長競聘
- 2024年業(yè)績換取股權(quán)的協(xié)議書模板
- 顳下頜關(guān)節(jié)疾病(口腔頜面外科學(xué)課件)
- 工業(yè)自動化設(shè)備維護(hù)保養(yǎng)指南
- 2024人教新版七年級上冊英語單詞英譯漢默寫表
評論
0/150
提交評論