Shell Sort(希爾排序)

來源:互聯網
上載者:User

標籤:需要   for   已耗用時間   增量   類比   排序演算法   排序   step   stream   

  這個排序演算法很厲害,我個人很喜歡這個演算法,但演算法的時間複雜度難計。演算法對增量(這裡也稱作step(步長))的選擇也需要注意,只記得個希爾增量的最壞情況為O(n^2)、Hibbard增量的最壞情況為O(n^3/2)(書上有證明),書上說Hibbard增量的希爾排序平均情形已耗用時間基於類比的結果被認為是O(n^5/4),但暫時沒人證明出這個結果。

  演算法的代碼實現有許多種,我就把《資料結構與演算法分析》上的代碼用C++敲了幾遍當做學習過了,順便學習C++,記不得的時候再回來複習。

  書《資料結構與演算法分析》中給出的代碼如下(希爾增量):

#include <iostream>#include <vector>using namespace std;class ShellSort {public:void shellSort(vector<int>& nums) {for(int Increment = (int)nums.size()/2; Increment > 0; Increment /= 2)for(int i = Increment; i < (int)nums.size(); i++) {int j, temp = nums[i];for(j = i; j >= Increment; j -= Increment)if(temp < nums[j - Increment])nums[j] = nums[j - Increment];elsebreak;nums[j] = temp;}}};int main() {vector<int> nums(5);ShellSort shellsort;for(int i = 0; i < (int)nums.size(); i++)cin >> nums[i];for(int i = 0; i < (int)nums.size(); i++)cout << nums[i] << ‘ ‘;cout << endl;shellsort.shellSort(nums);for(int i = 0; i < (int)nums.size(); i++)cout << nums[i] << ‘ ‘;return 0;}

  

Shell Sort(希爾排序)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.