C++下對冒泡排序算法的改進(jìn)_第1頁
C++下對冒泡排序算法的改進(jìn)_第2頁
C++下對冒泡排序算法的改進(jìn)_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡介

1、Visual C+下對冒泡排序算法的改進(jìn)作者:佚名 文章來源:天極 點(diǎn)擊數(shù): 更新時(shí)間:2005-8-30【字體:小 大】【發(fā)表評論】【加入我的收藏夾】【告訴好友】【打印此文】【關(guān)閉窗口】 摘 要:本文對排序中最常見的起泡法進(jìn)行分析,發(fā)現(xiàn)在實(shí)現(xiàn)單向起泡的同時(shí)可以實(shí)現(xiàn)雙向起泡,從而實(shí)現(xiàn)了冒泡算法的改進(jìn),提高了運(yùn)算速度。關(guān)鍵字:程序設(shè)計(jì)、起泡、雙向起泡、VC+排序是在程序設(shè)計(jì)中常碰到的問題,排序算法也有很多種。起泡法是眾所周知的排序算法,其原理是每次將相鄰兩個(gè)數(shù)進(jìn)行比較,較大的下沉。其的主程序段如下(用VC+實(shí)現(xiàn)):Void Bubble Sort (int* pData,int Cou

2、nt) Int iTemp; for(int i=1;i<Count;i+) For (int j=Count-1;j>=i;j-) if(pDataj<pDataj-1) iTemp = pDataj-1; pDataj-1 = pDataj; pDataj = iTemp; 我們分析上述程序段可以發(fā)現(xiàn)起泡法是從一端開始比較的,第一次循環(huán)就是把最小數(shù)上升到第一位置,第二次循環(huán)就是把第二最小數(shù)上升到第二位置。如此循環(huán)實(shí)現(xiàn)數(shù)據(jù)的排序。那么我們是否可以找到最小數(shù)的同時(shí)找到最大數(shù)呢?當(dāng)然可以。方法是在一端起泡時(shí)同時(shí)在另一端也進(jìn)行起泡。即反向起泡。下面的程序段實(shí)現(xiàn)的是雙向起泡:voi

3、d Bubble2Sort(int* pData,int Count) int iTemp; int left = 1; int right =Count -1; int t; do /正向的部分 for(int i=right;i>=left;i-) if(pDatai<pDatai-1) iTemp = pDatai; pDatai = pDatai-1; pDatai-1 = iTemp; t = i; left = t+1; /反向的部分 for(i=left;i<right+1;i+) if(pDatai<pDatai-1) iTemp = pDatai; pDatai = pDatai-1; pDatai-1 = iTemp; t = i; right = t-1; while(left<=right); 分析上面的程序段我們可以發(fā)現(xiàn)正向起泡時(shí)第一次循環(huán)找出了最小數(shù),反向起泡第一次循環(huán)找到最大數(shù)。很顯然在一次循環(huán)中即可

溫馨提示

  • 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論