頻道欄目
首頁 > 資訊 > php > 正文

PHP實現桶排序算法

18-01-09        來源:[db:作者]  
收藏   我要投稿
簡單意義上的桶排序:

桶排序的原理是先安排N+1個桶作為容器,若數據范圍為N的話。

然后將測試數據(所需排序的數據)進行循環,放入對應的桶內。數據一定是在范圍N內的。

最后,循環桶里的元素,并且輸出,進行從大到小或從小到大的排序。

例如:

我們的取值范圍是10,那么就要定義一個 11長度的數組$arr. 并且讓所有的元素值都為0

然后,對需要排序的數組進行循環 如5,3,5,2,8.(這邊取值范圍其實才8)

將數據依次對應$arr桶數組內元素,即 如果是5,則使$arr[5]++.

這時候 $arr[2]=1 $arr[3]=1 $arr[5]=2 $arr[8]=1

然后循環$arr的數組,若$arr[2]=1,則循環輸出元素2一次,$arr[5]=2,則循環輸出5兩次

結果輸出即為 2 3 5 5 8

如果循環數值是從大到小 則會是從大到小的排序

//設置默認數組,默認值為0;

$arr = array();

for ($i = 0; $i <= 10; $i++) {

$arr[$i] = 0;

}

//設置測試的五個數據

$arr1 = array(5, 3, 5, 2, 8);

//根據數據 對默認數組的對應元素進行+1; J的取值范圍不能等于$arr1數組長度

for ($j = 0; $j < count($arr1); $j++) {

//這邊給相應的數組值+1

$arr[$arr1[$j]]++;

}

//開始循環輸出 默認數組 $arr 里面相應的值

for ($k = 0; $k <= 10; $k++) {

for ($l=1; $l <=$arr[$k]; $l++) {

echo "$k ";

}

}

?>

缺點:

浪費空間.

無法進行浮點數據的排序.

相關TAG標簽
上一篇:PHP簡單選擇排序(Simple Selection Sort)算法學習
下一篇:用python實現的線程池實例代碼
相關文章
圖文推薦

關于我們 | 聯系我們 | 廣告服務 | 投資合作 | 版權申明 | 在線幫助 | 網站地圖 | 作品發布 | Vip技術培訓 | 舉報中心

版權所有: 紅黑聯盟--致力于做實用的IT技術學習網站

美女MM131爽爽爽毛片