欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解桶排序算法的思路及C++編程中的代碼實現(xiàn)

 更新時間:2016年07月06日 15:28:31   作者:kkun  
桶排序即是先把每個桶中的元素進(jìn)行排序然后遍歷桶依次列出元素的算法,桶排序在元素較少的情況下很高效,以下我們就來詳解桶排序算法的思路及C++編程中的代碼實現(xiàn):

算法思路理解
我自己的理解哈,可能與網(wǎng)上說的有一些出入,大體都是同樣的原理

無序數(shù)組有個要求,就是成員隸屬于固定(有限的)的區(qū)間,如范圍為[0-9](考試分?jǐn)?shù)為1-100等)

例如待排數(shù)字

[6 2 4 1 5 9]

準(zhǔn)備10個空桶,最大數(shù)個空桶

[6 2 4 1 5 9]  待排數(shù)組

[0 0 0 0 0 0 0 0 0 0] 空桶

[0 1 2 3 4 5 6 7 8 9] 桶編號(實際不存在)

1,順序從待排數(shù)組中取出數(shù)字,首先6被取出,然后把6入6號桶,這個過程類似這樣:空桶[ 待排數(shù)組[ 0 ] ] = 待排數(shù)組[ 0 ]

[6 2 4 1 5 9]  待排數(shù)組

[0 0 0 0 0 0 6 0 0 0] 空桶

[0 1 2 3 4 5 6 7 8 9] 桶編號(實際不存在)

2,順序從待排數(shù)組中取出下一個數(shù)字,此時2被取出,將其放入2號桶,是幾就放幾號桶

[6 2 4 1 5 9]  待排數(shù)組

[0 0 2 0 0 0 6 0 0 0] 空桶

[0 1 2 3 4 5 6 7 8 9] 桶編號(實際不存在)

3,4,5,6省略,過程一樣,全部入桶后變成下邊這樣

[6 2 4 1 5 9]  待排數(shù)組

[0 1 2 0 4 5 6 0 0 9] 空桶

[0 1 2 3 4 5 6 7 8 9] 桶編號(實際不存在)

0表示空桶,跳過,順序取出即可:

1 2 4 5 6 9

201676152256167.png (500×216)

C++示例:
以下是桶排序的c++程序,其中運用了list自帶的sort函數(shù)。

#include<iostream>
#include<list>
#include<algorithm>
using namespace std;
 
void bucketsort(double* a, int n) {
 list<double>* b = new list<double>[n];
 for (int i = 0; i < n; i++) {
 b[int(a[i])].push_back(a[i]);
 }
 for (int i = 0; i < n; i++) {
 b[i].sort();
 }
 for (int i = 0,j=0; i < n; i++) {
 while (b[j].size() < 1)j++;
 a[i] = b[j].front();
 b[j].pop_front();
 }
}
 
int main() {
 double arr[] = {0.1,1.1,2.2,3.5,1.5,2.3,7.5,1.7};
 int n = 8;
 bucketsort(arr, n);
 for (int i = 0; i < 8; i++) {
 cout << arr[i] << " ";
 }
 cout << endl;
 return 0;
}

程序運行結(jié)果:

201676152355715.png (326×91)

補充說明三點
1,桶排序是穩(wěn)定的
2,桶排序是常見排序里最快的一種,比快排還要快…大多數(shù)情況下
3,桶排序非常快,但是同時也非常耗空間,基本上是最耗空間的一種排序算法

相關(guān)文章

  • C++使用windwos?api實現(xiàn)獲取計算機基本信息

    C++使用windwos?api實現(xiàn)獲取計算機基本信息

    這篇文章主要為大家詳細(xì)介紹了C++如何使用windwos?api實現(xiàn)獲取windwos計算機的基本信息,包括計算機名稱、操作系統(tǒng)版本、處理器信息等,需要的可以參考一下
    2023-04-04
  • C語言使用realloc函數(shù)實現(xiàn)通訊錄源碼分析

    C語言使用realloc函數(shù)實現(xiàn)通訊錄源碼分析

    什么是動態(tài)通訊錄,就是在靜態(tài)的基礎(chǔ)上改進(jìn)了一下,不在使用數(shù)組,而是使用指針和動態(tài)內(nèi)存開辟的函數(shù),當(dāng)空間不夠的時候,便進(jìn)行增容
    2023-02-02
  • C++中的String的常用函數(shù)用法(最新推薦)

    C++中的String的常用函數(shù)用法(最新推薦)

    這篇文章主要介紹了C++中的String的常用函數(shù)用法總結(jié),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • 基于C語言代碼實現(xiàn)點餐系統(tǒng)

    基于C語言代碼實現(xiàn)點餐系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了基于C語言代碼實現(xiàn)點餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • 淺析多維數(shù)組的下標(biāo)重載

    淺析多維數(shù)組的下標(biāo)重載

    貼一下實現(xiàn)基本功能的代碼吧,像越界檢測,及其他功能就沒寫了,只要體現(xiàn)了思路,其他的功能好加
    2013-09-09
  • Qt中網(wǎng)絡(luò)編程的實現(xiàn)

    Qt中網(wǎng)絡(luò)編程的實現(xiàn)

    本文主要介紹了Qt中網(wǎng)絡(luò)編程的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-02-02
  • C++中l(wèi)ist容器的實現(xiàn)

    C++中l(wèi)ist容器的實現(xiàn)

    本文主要介紹了C++中l(wèi)ist容器的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • C語言實現(xiàn)會員管理系統(tǒng)

    C語言實現(xiàn)會員管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)會員管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++貪心算法實現(xiàn)活動安排問題(實例代碼)

    C++貪心算法實現(xiàn)活動安排問題(實例代碼)

    貪心算法(又稱貪婪算法)是指,在對問題求解時,總是做出在當(dāng)前看來是最好的選擇。這篇文章主要介紹了C++貪心算法實現(xiàn)活動安排問題,需要的朋友可以參考下
    2019-11-11
  • Qt?自定義屬性Q_PROPERTY不顯示float類型的解決

    Qt?自定義屬性Q_PROPERTY不顯示float類型的解決

    這篇文章主要介紹了Qt?自定義屬性Q_PROPERTY不顯示float類型的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論