国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 邏輯算法 > 正文

PHP排序算法系列之桶排序的詳解

2020-03-22 16:38:59
字體:
來源:轉載
供稿:網友
這篇文章主要為大家詳細介紹了PHP排序算法系列之桶排序,具有一定的參考價值,感興趣的小伙伴們可以參考一下

桶排序

桶排序(Bucket sort)或所謂的箱排序,是一個排序算法,工作的原理是將數組分到有限數量的桶里。每個桶再個別排序(有可能再使用別的排序算法或是以遞歸方式繼續使用桶排序進行排序)。桶排序是鴿巢排序的一種歸納結果。當要被排序的數組內的數值是均勻分配的時候,桶排序使用線性時間(Θ(n))。但桶排序并不是比較排序,他不受到O(n log n)下限的影響。

原理

設置一個定量的數組當作空桶子。
尋訪序列,并且把項目一個一個放到對應的桶子去。
對每個不是空的桶子進行排序。
從不是空的桶子里把項目再放回原來的序列中。

舉例

假定待排數字[6 2 4 1 5 9]

準備10個空桶,最大數個空桶
[0 0 0 0 0 0 0 0 0 0] 空桶
[0 1 2 3 4 5 6 7 8 9] 桶編號(實際不存在)

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

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

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

[6 2 4 1 5 9] 待排數組
[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] 待排數組
[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

PHP代碼實現

 ?phpfunction bucket_sort($arr){ $result=[]; $length=count($arr); //入桶 for($i=0,$max=$arr[$i];$i $length;$i++){ if ($max $arr[$i]) { $max=$arr[$i]; $bucket[$arr[$i]]=[]; array_push($bucket[$arr[$i]],$arr[$i]); //出桶 for($i=0;$i =$max;$i++){ if(!empty($bucket[$i])){ $l=count($bucket[$i]); for ($j=0; $j $j++) { $result[]=$bucket[$i][$j]; return $result;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持php 。

您可能感興趣的文章:

PHP排序算法系列之歸并排序詳解_php技巧

PHP排序算法系列之直接選擇排序的詳解

PHP排序算法系列之插入排序的詳解

以上就是PHP排序算法系列之桶排序的詳解的詳細內容,PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广昌县| 木里| 青川县| 明光市| 南郑县| 泽普县| 广河县| 罗田县| 临夏县| 囊谦县| 晴隆县| 石嘴山市| 晋州市| 皋兰县| 商丘市| 曲阜市| 嘉黎县| 遂溪县| 塔河县| 镇沅| 从化市| 凤台县| 江门市| 芦山县| 乐东| 建宁县| 新乡市| 孟州市| 吉安县| 正安县| 陇南市| 壤塘县| 福安市| 宁蒗| 鹤壁市| 双柏县| 泽普县| 柘城县| 湘潭县| 黄梅县| 云霄县|