排序算法之PHP版快速排序、冒泡排序
一、快速排序
1.簡(jiǎn)介
快速排序是由東尼·霍爾所發(fā)展的一種排序算法。在平均狀況下,排序 n 個(gè)項(xiàng)目要Ο(n log n)次比較。在最壞狀況下則需要Ο(n2)次比較,但這種狀況并不常見(jiàn)。事實(shí)上,快速排序通常明顯比其他Ο(n log n) 算法更快,因?yàn)樗膬?nèi)部循環(huán)(inner loop)可以在大部分的架構(gòu)上很有效率地被實(shí)現(xiàn)出來(lái)。
快速排序使用分治法(Divide and conquer)策略來(lái)把一個(gè)串行(list)分為兩個(gè)子串行(sub-lists)。
2.步驟
從數(shù)列中挑出一個(gè)元素,稱(chēng)為 “基準(zhǔn)”(pivot),
重新排序數(shù)列,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面(相同的數(shù)可以到任一邊)。在這個(gè)分區(qū)退出之后,該基準(zhǔn)就處于數(shù)列的中間位置。這個(gè)稱(chēng)為分區(qū)(partition)操作。
遞歸地(recursive)把小于基準(zhǔn)值元素的子數(shù)列和大于基準(zhǔn)值元素的子數(shù)列排序。
3.代碼實(shí)現(xiàn)
{
$len = count($array);
if($len <= 1)
{
return $array;
}
$key = $array[0];
$left = array();
$right = array();
for($i=1; $i<$len; ++$i)
{
if($array[$i] < $key)
{
$left[] = $array[$i];
}
else
{
$right[] = $array[$i];
}
}
$left = quickSort($left);
$right = quickSort($right);
return array_merge($left, array($key), $right);
}
print '<pre>';
print_r(quickSort(array(1,4,22,5,7,6,9)));
print '</pre>';
4.排序效果
使用快速排序法對(duì)一列數(shù)字進(jìn)行排序的過(guò)程

二、冒泡排序
1.簡(jiǎn)介
冒泡排序(Bubble Sort)是一種簡(jiǎn)單的排序算法。它重復(fù)地走訪過(guò)要排序的數(shù)列,一次比較兩個(gè)元素,如果他們的順序錯(cuò)誤就把他們交換過(guò)來(lái)。走訪數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換,也就是說(shuō)該數(shù)列已經(jīng)排序完成。這個(gè)算法的名字由來(lái)是因?yàn)樵叫〉脑貢?huì)經(jīng)由交換慢慢“浮”到數(shù)列的頂端。
2.步驟
比較相鄰的元素。如果第一個(gè)比第二個(gè)大,就交換他們兩個(gè)。
對(duì)每一對(duì)相鄰元素作同樣的工作,從開(kāi)始第一對(duì)到結(jié)尾的最后一對(duì)。在這一點(diǎn),最后的元素應(yīng)該會(huì)是最大的數(shù)。
針對(duì)所有的元素重復(fù)以上的步驟,除了最后一個(gè)。
持續(xù)每次對(duì)越來(lái)越少的元素重復(fù)上面的步驟,直到?jīng)]有任何一對(duì)數(shù)字需要比較。
3.代碼實(shí)現(xiàn)
function bubbingSort(array $array)
{
for($i=0, $len=count($array)-1; $i<$len; ++$i)
{
for($j=$len; $j>$i; --$j)
{
if($array[$j] < $array[$j-1])
{
$temp = $array[$j];
$array[$j] = $array[$j-1];
$array[$j-1] = $temp;
}
}
}
return $array;
}
print '<pre>';
print_r(bubbingSort(array(1,4,22,5,7,6,9)));
print '</pre>';
4.排序過(guò)程
使用冒泡排序?yàn)橐涣袛?shù)字進(jìn)行排序的過(guò)程

- PHP經(jīng)典算法集錦【經(jīng)典收藏】
- php經(jīng)典算法集錦
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php實(shí)現(xiàn)的常見(jiàn)排序算法匯總
- PHP四種基本排序算法示例
- 使用PHP實(shí)現(xiàn)二分查找算法代碼分享
- PHP實(shí)現(xiàn)字符串翻轉(zhuǎn)功能的方法【遞歸與循環(huán)算法】
- PHP 加密解密內(nèi)部算法
- PHP面試常用算法(推薦)
- PHP常用算法和數(shù)據(jù)結(jié)構(gòu)示例(必看篇)
- PHP各種常見(jiàn)經(jīng)典算法總結(jié)【排序、查找、翻轉(zhuǎn)等】
相關(guān)文章
ThinkPHP中SHOW_RUN_TIME不能正常顯示運(yùn)行時(shí)間的解決方法
這篇文章主要介紹了ThinkPHP中SHOW_RUN_TIME不能正常顯示運(yùn)行時(shí)間的解決方法,針對(duì)ThinkPHP配置文件config.php設(shè)置SHOW_RUN_TIME后不能顯示運(yùn)行時(shí)間情況下的解決方法,涉及針對(duì)ThinkPHP底層源文件的修改,需要的朋友可以參考下2015-10-10
php處理restful請(qǐng)求的路由類(lèi)分享
利用路由表與restful url進(jìn)行匹配,分發(fā)到不同的action處理,最基本的實(shí)現(xiàn),只考慮路由分發(fā)功能2014-02-02
Drupal7連接多個(gè)數(shù)據(jù)庫(kù)及常見(jiàn)問(wèn)題解決
這篇文章主要介紹了Drupal7連接多個(gè)數(shù)據(jù)庫(kù)的方法、操作實(shí)例,以及常見(jiàn)問(wèn)題解決方法,需要的朋友可以參考下2014-03-03
PHP抓取淘寶商品的用戶曬單評(píng)論+圖片+搜索商品列表實(shí)例
下面是小編在前段時(shí)間做淘寶客引發(fā)的一些思考,有關(guān)PHP抓取淘寶商品的用戶曬單評(píng)論+圖片實(shí)例的方法,需要的朋友參考下吧2016-04-04
php實(shí)現(xiàn)文本數(shù)據(jù)導(dǎo)入SQL SERVER
php將文本文件導(dǎo)入mysql我們經(jīng)常遇到,但是如果是導(dǎo)入到sqlserver又應(yīng)該如何操作呢,下面就給大家分享一下本人的操作方法,感覺(jué)效率還不錯(cuò),這里推薦給大家。2015-05-05
PHP會(huì)員找回密碼功能的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇PHP會(huì)員找回密碼功能的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
PHP獲取不了React Native Fecth參數(shù)的解決辦法
這篇文章的主要內(nèi)容是解決PHP獲取不了React Native Fecth參數(shù)的問(wèn)題,本文通過(guò)示例詳細(xì)解釋如何解決這個(gè)問(wèn)題,相信對(duì)大家的理解更有幫助,如果有這個(gè)問(wèn)題的可以參考下本文,下面跟著小編一起來(lái)看看。2016-08-08
分享PHP源碼批量抓取遠(yuǎn)程網(wǎng)頁(yè)圖片并保存到本地的實(shí)現(xiàn)方法
本篇文章給大家分享PHP源碼批量抓取遠(yuǎn)程網(wǎng)頁(yè)圖片并保存到本地的實(shí)現(xiàn)方法,對(duì)批量抓取網(wǎng)頁(yè)圖片相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2015-12-12

