簡單的桶排序

問題

對n個0~1000的數(shù)進行排序。

解決問題的思想

可以用一個長度為1001的列表中的每一個位置表示一個桶,每個桶用來標記每個數(shù)出現(xiàn)的次數(shù)。最后從前往后遍歷每一個桶,每個桶標記的次數(shù)是多少,這個桶的下標就打印多少次,輸出結(jié)果即為升序排列。


Paste_Image.png

python代碼實現(xiàn)

#!/usr/bin/python
# encoding: utf-8

import random

# 簡單的桶排序算法

# 生成一百個0~1000的隨機數(shù)
source = [random.randint(0,1000) for i in range(0, 101)]

# 構(gòu)造空桶(長度為1001的列表,每個列表的值初始化為0)
bucket = [0 for i in range(0, 1001)]

# 進行計數(shù),每出現(xiàn)一個數(shù),對應的桶的值加一
for i in source:
    bucket[i] += 1

# 從第一個桶遍歷到最后一個桶
for i in range(0, 1001, 1):
    # 這個桶的值出現(xiàn)多少次,就打印多少次
    for j in range(1, bucket[i] + 1):
        print(i),

運行結(jié)果

0 7 12 18 19 31 49 52 63 64 68 74 90 93 98 114 114 119 131 133 138 140 160 162 166 193 201 205 238 254 257 266 277 285 287 306 307 310 322 362 368 373 374 396 415 424 430 439 442 463 463 465 467 481 494 508 529 545 553 569 571 572 593 602 608 619 624 644 645 645 662 663 669 674 680 683 686 691 714 765 766 778 784 786 797 802 813 835 840 841 842 887 888 897 905 929 930 943 945 973 975

時間復雜度

  • 構(gòu)造空桶循環(huán)了m次(m為桶的個數(shù)),進行計數(shù)循環(huán)了n次(n為待排序數(shù)的個數(shù)),最后遍歷輸出循環(huán)了m+n次,所以總共執(zhí)行了2(m+n)次。所以時間復雜度為O(n)

桶排序的缺點:

  • 如果排序樹的范圍在0~10000000,那就需要這么大的list作為空桶,可能排序數(shù)的長度只有幾十個,顯然用桶排序很消耗空間。
    復雜的桶排序:可以考慮每個桶裝有不同的值,分配完桶后,對每個桶中的數(shù)據(jù)進行排序算法即可。

*參考資料:《啊哈!算法》 *

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • 概述:排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    每天刷兩次牙閱讀 3,828評論 0 15
  • 概述 排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    蟻前閱讀 5,303評論 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 將一個記錄插入到已排序好...
    依依玖玥閱讀 1,354評論 0 2
  • 母親常常跟我說:不要把每個人想的都太好了。 我不以為然,單純地想那是母親把人心想的太壞了。 人心能有多壞,這我倒是...
    任小希閱讀 221評論 0 0
  • 下載JDK JDK官方下載地址 解壓安裝包 tar -zxvf jdk-8u121-linux-x64.tar.g...
    Gavin的小窩閱讀 239評論 0 1

友情鏈接更多精彩內(nèi)容