程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> 經典四講貫通C++排序之四 選擇排序(1)

經典四講貫通C++排序之四 選擇排序(1)

編輯:C++入門知識

我們都知道C++排序方法中,有四種常用方法插入排序希爾排序交換排序以及選擇排序。這篇文章我們介紹選擇排序。本系列文章統一 測試程序

選擇排序

基本思想是:每次選出第i小的記錄,放在第i個位置(i的起點是0,按此說法,第0小的記錄實際上就是最小的,有點別扭,不管這麼多了)。當i=N-1時就排完了。

直接選擇排序

直選排序簡單的再現了選擇排序的基本思想,第一次尋找最小元素的代價是O(n),如果不做某種特殊處理,每次都使用最簡單的尋找方法,自然的整個排序的時間復雜度就是O(n2)了。

  1. template <class T>  
  2. void SelectSort(T a[], int N, int& KCN, int& RMN)  
  3. {  
  4. KCN = 0; RMN = 0;  
  5. for (int i = 0; i < N; i++)  
  6. {  
  7. for (int j = i + 1, k = i; j < N; j++) if (++KCN && a[j] < a[k]) k = j;//select min  
  8. if (k != i) { swap(a[k], a[i]); RMN += 3; }  
  9. }  

測試結果:

  1. Sort ascending N=10000 TimeSpared: 721ms  
  2. KCN=49995000 KCN/N=4999.5 KCN/N^2=0.49995 KCN/NlogN=376.25  
  3. RMN=0 RMN/N=0 RMN/N^2=0 RMN/NlogN=0  
  4. Sort randomness N=10000 TimeSpared: 711ms  
  5. KCN=49995000 KCN/N=4999.5 KCN/N^2=0.49995 KCN/NlogN=376.25  
  6. RMN=29955 RMN/N=2.9955 RMN/N^2=0.00029955 RMN/NlogN=0.225434  
  7. Sort descending N=10000 TimeSpared: 711ms  
  8. KCN=49995000 KCN/N=4999.5 KCN/N^2=0.49995 KCN/NlogN=376.25  
  9. RMN=15000 RMN/N=1.5 RMN/N^2=0.00015 RMN/NlogN=0.112886 

可以看到KCN固定為n(n-1)/2。另外一件有趣的事是,RMN=0的正序花的時間居然比RMN接近3(n-1)的亂序還多。一是說明測試精度不夠,在我的機器上多次測試結果上下浮動10ms是常有的事;二是說明和KCN的n(n-1)/2相比,RMN的3(n-1)有些微不足道。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved