C++下對冒泡排序算法的改進_第1頁
C++下對冒泡排序算法的改進_第2頁
C++下對冒泡排序算法的改進_第3頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、Visual C+下對冒泡排序算法的改進作者:佚名 文章來源:天極 點擊數: 更新時間:2005-8-30【字體:小 大】【發表評論】【加入我的收藏夾】【告訴好友】【打印此文】【關閉窗口】 摘 要:本文對排序中最常見的起泡法進行分析,發現在實現單向起泡的同時可以實現雙向起泡,從而實現了冒泡算法的改進,提高了運算速度。關鍵字:程序設計、起泡、雙向起泡、VC+排序是在程序設計中常碰到的問題,排序算法也有很多種。起泡法是眾所周知的排序算法,其原理是每次將相鄰兩個數進行比較,較大的下沉。其的主程序段如下(用VC+實現):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; 我們分析上述程序段可以發現起泡法是從一端開始比較的,第一次循環就是把最小數上升到第一位置,第二次循環就是把第二最小數上升到第二位置。如此循環實現數據的排序。那么我們是否可以找到最小數的同時找到最大數呢?當然可以。方法是在一端起泡時同時在另一端也進行起泡。即反向起泡。下面的程序段實現的是雙向起泡: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); 分析上面的程序段我們可以發現正向起泡時第一次循環找出了最小數,反向起泡第一次循環找到最大數。很顯然在一次循環中即可

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論