




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、北京郵電大學(xué)信息與通信工程學(xué)院數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)名稱(chēng): 實(shí)驗(yàn)3排序?qū)W生姓名: 滿(mǎn)興源班 級(jí): 2014211105班內(nèi)序號(hào): 15學(xué) 號(hào): 2014210128日 期: 2015年12月28日1 實(shí)驗(yàn)要求使用簡(jiǎn)單數(shù)組實(shí)現(xiàn)下面各種排序算法,并進(jìn)行比較。排序算法:1、插入排序2、希爾排序3、冒泡排序4、快速排序5、簡(jiǎn)單選擇排序6、堆排序(選作)7、歸并排序(選作)8、基數(shù)排序(選作)9、其他要求:1、測(cè)試數(shù)據(jù)分成三類(lèi):正序、逆序、隨機(jī)數(shù)據(jù)2、對(duì)于這三類(lèi)數(shù)據(jù),比較上述排序算法中關(guān)鍵字的比較次數(shù)和移動(dòng)次數(shù)(其中關(guān)鍵字交換計(jì)為3次移動(dòng))。3、對(duì)于這三類(lèi)數(shù)據(jù),比較上述排序算法中不同算法的執(zhí)行時(shí)間,精確到
2、微秒(選作)4、對(duì)2和3的結(jié)果進(jìn)行分析,驗(yàn)證上述各種算法的時(shí)間復(fù)雜度編寫(xiě)測(cè)試main()函數(shù)測(cè)試排序算法的正確性。2.1 存儲(chǔ)結(jié)構(gòu) 順序存儲(chǔ)結(jié)構(gòu)數(shù)組2.2 關(guān)鍵算法分析1. 插入排序:依次將待排序的序列中的每一個(gè)記錄插入到先前排序好的序列中,直到全部記錄排序完畢void Insertsort(int r, int n)for (int i = 2; i <= n; i+)if (ri < ri - 1)int j;r0 = ri;ri = ri - 1;for (j = i - 2; r0 < rj; j-)rj + 1 = rj;rj + 1 = r0;2. 希爾排序:先將
3、整個(gè)序列分割成若干個(gè)子列,分別在各個(gè)子列中運(yùn)用直接插入排序,待整個(gè)序列基本有序時(shí),再對(duì)全體記錄進(jìn)行一次直接插入排序void ShellInsert(int r, int n)int j;for (int d = n / 2; d >= 1; d = d / 2)for (int i = d + 1; i <= n; i+)if (ri < ri - 1)r0 = ri;for (j = i - d; j>0 && r0<rj; j = j - d)rj + d = rj;rj + d = r0;3. 冒泡排序:兩兩比較相鄰記錄的關(guān)鍵碼,如果反序則交
4、換,直到?jīng)]有反序記錄為止void BubbleSort(int r, int n)int pos = n;while (pos != 0)int bound = pos;pos = 0;for (int i = 1; i < bound; i+)if (ri>ri + 1)r0 = ri;ri = ri + 1;ri + 1 = r0;pos = i;4. 快速排序:首先選擇一個(gè)基準(zhǔn),將記錄分割為兩部分,左支小于或等于基準(zhǔn),右支則大于基準(zhǔn),然后對(duì)兩部分重復(fù)上述過(guò)程,直至整個(gè)序列排序完成int Partion(int r, int first, int end)int i = fir
5、st;int j = end;int pivot = ri;while (i < j)while (i < j) && (rj >= pivot)j-;ri = rj;while (i < j) && (ri <= pivot)i+;rj = ri;ri = pivot;return i;void QSort(int r, int i, int j)if (i <j)int pivotloc = Partion(r, i, j);QSort(r, i, pivotloc - 1);QSort(r, pivotloc + 1,
6、j);5. 選擇排序:從待排序的記錄序列中選擇關(guān)鍵碼最小的記錄并將它與序列中的第一個(gè)記錄交換位置;然后從不包括第一個(gè)位置上的記錄序列中選擇關(guān)鍵碼最小(或最大)的記錄并將它與序列中的第二個(gè)記錄交換位置;如此重復(fù),直到序列中只剩下一個(gè)記錄為止void SelectSort(int r, int n)for (int i = 1; i < n; i+)int index = i;for (int j = i + 1; j <= n; j+)if (rj < rindex)index = j;if (index != i)r0 = ri;ri = rindex;rindex = r0
7、;用戶(hù)輸入數(shù)組開(kāi)始3. 程序運(yùn)行結(jié)果3.1主函數(shù)流程圖五種排序輸出結(jié)果結(jié)束3.2程序運(yùn)行框圖源代碼:#include<iostream>using namespace std;void print(int r, int n)for (int i = 1; i <= n; i+)cout << ri << " "cout << endl;/*插入排序*/void Insertsort(int r, int n)for (int i = 2; i <= n; i+)if (ri < ri - 1)int j;r0
8、 = ri;ri = ri - 1;for (j = i - 2; r0 < rj; j-)rj + 1 = rj;rj + 1 = r0;/*希爾排序*/void ShellInsert(int r, int n)int j;for (int d = n / 2; d >= 1; d = d / 2)for (int i = d + 1; i <= n; i+)if (ri < ri - 1)r0 = ri;for (j = i - d; j>0 && r0<rj; j = j - d)rj + d = rj;rj + d = r0;/*改
9、進(jìn)的冒泡排序*/void BubbleSort(int r, int n)int pos = n;while (pos != 0)int bound = pos;pos = 0;for (int i = 1; i < bound; i+)if (ri>ri + 1)r0 = ri;ri = ri + 1;ri + 1 = r0;pos = i;/*快速排序*/int Partion(int r, int first, int end)int i = first;int j = end;int pivot = ri;while (i < j)while (i < j) &
10、amp;& (rj >= pivot)j-;ri = rj;while (i < j) && (ri <= pivot)i+;rj = ri;ri = pivot;return i;void QSort(int r, int i, int j)if (i <j)int pivotloc = Partion(r, i, j);QSort(r, i, pivotloc - 1);QSort(r, pivotloc + 1, j);/*簡(jiǎn)單選擇排序*/void SelectSort(int r, int n)for (int i = 1; i <
11、 n; i+)int index = i;for (int j = i + 1; j <= n; j+)if (rj < rindex)index = j;if (index != i)r0 = ri;ri = rindex;rindex = r0;void main()int x;int n = 10;int rr11 ,a11 ;rr0 = -1;cout << "請(qǐng)輸入需要排序的數(shù)組:"for (int i = 1; i <= 10; i+)cin >> x;rri = x;for (int i = 1; i <= 10
12、; i+)ai = rri;Insertsort(rr, n);cout << "插入排序法排序后的數(shù)為:" << endl;print(rr, 10);for (int i = 1; i <= 10; i+)rri = ai;ShellInsert(rr, n);cout << "希爾排序法排序后的數(shù)為:" << endl;print(rr, 10);for (int i = 1; i <= 10; i+)rri = ai;BubbleSort(rr, n);cout << &qu
13、ot;冒泡排序法(改進(jìn))排序后的數(shù)為:" << endl;print(rr, 10);for (int i = 1; i <= 10; i+)rri = ai;QSort(rr, 1, n);cout << "快速排序法排序后的數(shù)為:" << endl;print(rr, 10);for (int i = 1; i <= 10; i+)rri = ai;SelectSort(rr, n);cout << "簡(jiǎn)單選擇排序法排序后的數(shù)為:" << endl;print(rr, 10);for (int i = 1; i <= 10; i+)rri = ai;4. 總結(jié)1.調(diào)試時(shí)出
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 液壓與液力技術(shù)在健身器材中的應(yīng)用考核試卷
- 社交心理學(xué)在決策制定中的應(yīng)用考核試卷
- 電池充放電特性與循環(huán)壽命考核試卷
- 紡織原料與絹紡質(zhì)量控制考核試卷
- 漁業(yè)機(jī)械人機(jī)工程學(xué)應(yīng)用考核試卷
- 纖維素纖維在鞋類(lèi)產(chǎn)品抗滑性與耐磨性改進(jìn)考核試卷
- 礦山機(jī)械故障案例分析與預(yù)防考核試卷
- 天津藝術(shù)職業(yè)學(xué)院《細(xì)胞與組織工程》2023-2024學(xué)年第二學(xué)期期末試卷
- 山東省泰安市第一中學(xué)2025年高中畢業(yè)班第二次統(tǒng)測(cè)物理試題含解析
- 山東省棗莊樹(shù)人中學(xué)2024-2025學(xué)年初三化學(xué)試題5月模擬試題含解析
- 基于全生命周期的綠色建筑成本影響因素研究
- 2025年普法知識(shí)競(jìng)賽題庫(kù)及答案(共80題)
- 碎石外包合同協(xié)議
- 心力衰竭護(hù)理查房 課件
- 【課時(shí)練基礎(chǔ)作業(yè)】人教版四年級(jí)數(shù)學(xué)下冊(cè)第四單元《期中計(jì)算能力測(cè)試》(含答案)
- 2025年第三屆天揚(yáng)杯建筑業(yè)財(cái)稅知識(shí)競(jìng)賽題庫(kù)附答案(1001-1536題)
- 2025科技輔導(dǎo)員培訓(xùn)
- 樹(shù)木修剪合同協(xié)議
- 新疆維吾爾自治區(qū)2024年普通高校招生普通類(lèi)國(guó)家及地方專(zhuān)項(xiàng)、南疆單列、對(duì)口援疆計(jì)劃 本科一批次投檔情況 (理工)
- 智研咨詢(xún)發(fā)布:2025年紙漿模塑餐飲具行業(yè)市場(chǎng)規(guī)模及主要企業(yè)市占率分析報(bào)告
- 2025年CCAA《管理體系認(rèn)證基礎(chǔ)》考前必練題庫(kù)500題(含真題、重點(diǎn)題)
評(píng)論
0/150
提交評(píng)論