聽歡哥講PHP之四種排序算法

PHP 實現(xiàn)四種基本排序算法

許多人都說算法是程序的核心,算法的好壞決定了程序的質量垃沦。作為一個初級phper客给,雖然很少接觸到算法方面的東西。但是對于基本的排序算法還是應該掌握的肢簿,它是程序開發(fā)的必備工具靶剑。這里介紹冒泡排序,插入排序池充,選擇排序桩引,快速排序四種基本算法,分析一下算法的思路收夸。

(題圖來自:robinhoodsplayground.com)

前提:分別用冒泡排序法坑匠,快速排序法,選擇排序法卧惜,插入排序法將下面數(shù)組中的值按照從小到大的順序進行排序厘灼。

$arr(1,43,54,62,21,66,32,78,36,76,39);

1.?冒泡排序

思路分析:在要排序的一組數(shù)中,對當前還未排好的序列咽瓷,從前往后對相鄰的兩個數(shù)依次進行比較和調(diào)整设凹,讓較大的數(shù)往下沉,較小的往上冒茅姜。即闪朱,每當兩相鄰的數(shù)比較后發(fā)現(xiàn)它們的排序與排序要求相反時,就將它們互換。

代碼實現(xiàn):

$arr=array(1,43,54,62,21,66,32,78,36,76,39);

functionbubbleSort($arr)

{

$len=count($arr);

//該層循環(huán)控制?需要冒泡的輪數(shù)

for($i=1;$i<$len;$i++)

{//該層循環(huán)用來控制每輪?冒出一個數(shù)?需要比較的次數(shù)

for($k=0;$k<$len-$i;$k++)

{

if($arr[$k]>$arr[$k+1])

{

$tmp=$arr[$k+1];

$arr[$k+1]=$arr[$k];

$arr[$k]=$tmp;

}

}

}

return$arr;

}

2.?選擇排序

思路分析:在要排序的一組數(shù)中监透,選出最小的一個數(shù)與第一個位置的數(shù)交換桶错。然后在剩下的數(shù)當中再找最小的與第二個位置的數(shù)交換,如此循環(huán)到倒數(shù)第二個數(shù)和最后一個數(shù)比較為止胀蛮。

代碼實現(xiàn):

functionselectSort($arr){

//雙重循環(huán)完成院刁,外層控制輪數(shù),內(nèi)層控制比較次數(shù)

$len=count($arr);

for($i=0;$i<$len-1;$i++){

//先假設最小的值的位置

$p=$i;

for($j=$i+1;$j<$len;$j++){

//$arr[$p]?是當前已知的最小值

if($arr[$p]>$arr[$j]){

//比較粪狼,發(fā)現(xiàn)更小的,記錄下最小值的位置退腥;并且在下次比較時采用已知的最小值進行比較。

$p=$j;

}

}

//已經(jīng)確定了當前的最小值的位置再榄,保存到$p中狡刘。如果發(fā)現(xiàn)最小值的位置與當前假設的位置$i不同,則位置互換即可困鸥。

if($p!=$i){

$tmp=$arr[$p];

$arr[$p]=$arr[$i];

$arr[$i]=$tmp;

}

}

//返回最終結果

return$arr;

}

3.插入排序

思路分析:在要排序的一組數(shù)中嗅蔬,假設前面的數(shù)已經(jīng)是排好順序的,現(xiàn)在要把第n個數(shù)插到前面的有序數(shù)中疾就,使得這n個數(shù)也是排好順序的澜术。如此反復循環(huán),直到全部排好順序猬腰。

代碼實現(xiàn):

functioninsertSort($arr){

$len=count($arr);

for($i=1,$i<$len;$i++){

$tmp=$arr[$i];

//內(nèi)層循環(huán)控制鸟废,比較并插入

for($j=$i-1;$j>=0;$j--){

if($tmp<$arr[$j]){

//發(fā)現(xiàn)插入的元素要小,交換位置姑荷,將后邊的元素與前面的元素互換

$arr[$j+1]=$arr[$j];

$arr[$j]=$tmp;

}else{

//如果碰到不需要移動的元素盒延,由于是已經(jīng)排序好是數(shù)組,則前面的就不需要再次比較了鼠冕。

break;

}

}

}

return$arr;

}

4.快速排序

思路分析:選擇一個基準元素添寺,通常選擇第一個元素或者最后一個元素。通過一趟掃描供鸠,將待排序列分成兩部分畦贸,一部分比基準元素小,一部分大于等于基準元素楞捂。此時基準元素在其排好序后的正確位置薄坏,然后再用同樣的方法遞歸地排序劃分的兩部分。

代碼實現(xiàn):

functionquickSort($arr){

//先判斷是否需要繼續(xù)進行

$length=count($arr);

if($length<=1){

return$arr;

}

//選擇第一個元素作為基準

$base_num=$arr[0];

//遍歷除了標尺外的所有元素寨闹,按照大小關系放入兩個數(shù)組內(nèi)

//初始化兩個數(shù)組

$left_array=array();//小于基準的

$right_array=array();//大于基準的

for($i=1;$i<$length;$i++){

if($base_num>$arr[$i]){

//放入左邊數(shù)組

$left_array[]=$arr[$i];

}else{

//放入右邊

$right_array[]=$arr[$i];

}

}

//再分別對左邊和右邊的數(shù)組進行相同的排序處理方式遞歸調(diào)用這個函數(shù)

$left_array=quick_sort($left_array);

$right_array=quick_sort($right_array);

//合并

returnarray_merge($left_array,array($base_num),$right_array);

}

更多PHP相關技術請搜索千鋒PHP胶坠,做真實的自己,用良心做教育

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末繁堡,一起剝皮案震驚了整個濱河市沈善,隨后出現(xiàn)的幾起案子乡数,更是在濱河造成了極大的恐慌,老刑警劉巖闻牡,帶你破解...
    沈念sama閱讀 212,294評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件净赴,死亡現(xiàn)場離奇詭異,居然都是意外死亡罩润,警方通過查閱死者的電腦和手機玖翅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,493評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來割以,“玉大人金度,你說我怎么就攤上這事⊙狭ぃ” “怎么了猜极?”我有些...
    開封第一講書人閱讀 157,790評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長消玄。 經(jīng)常有香客問我跟伏,道長,這世上最難降的妖魔是什么莱找? 我笑而不...
    開封第一講書人閱讀 56,595評論 1 284
  • 正文 為了忘掉前任酬姆,我火速辦了婚禮,結果婚禮上奥溺,老公的妹妹穿的比我還像新娘。我一直安慰自己骨宠,他們只是感情好浮定,可當我...
    茶點故事閱讀 65,718評論 6 386
  • 文/花漫 我一把揭開白布层亿。 她就那樣靜靜地躺著桦卒,像睡著了一般匿又。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上碌更,一...
    開封第一講書人閱讀 49,906評論 1 290
  • 那天裕偿,我揣著相機與錄音,去河邊找鬼痛单。 笑死嘿棘,一個胖子當著我的面吹牛旭绒,可吹牛的內(nèi)容都是我干的鸟妙。 我是一名探鬼主播,決...
    沈念sama閱讀 39,053評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼重父,長吁一口氣:“原來是場噩夢啊……” “哼花椭!你這毒婦竟也來了?” 一聲冷哼從身側響起房午,我...
    開封第一講書人閱讀 37,797評論 0 268
  • 序言:老撾萬榮一對情侶失蹤矿辽,失蹤者是張志新(化名)和其女友劉穎歪沃,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沪曙,經(jīng)...
    沈念sama閱讀 44,250評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,570評論 2 327
  • 正文 我和宋清朗相戀三年液走,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缘眶。...
    茶點故事閱讀 38,711評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖巷懈,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情顶燕,我是刑警寧澤,帶...
    沈念sama閱讀 34,388評論 4 332
  • 正文 年R本政府宣布欧引,位于F島的核電站,受9級特大地震影響芝此,放射性物質發(fā)生泄漏。R本人自食惡果不足惜因痛,卻給世界環(huán)境...
    茶點故事閱讀 40,018評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望租副。 院中可真熱鬧,春花似錦用僧、人聲如沸结胀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,796評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽院仿。三九已至,卻和暖如春歹垫,著一層夾襖步出監(jiān)牢的瞬間剥汤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,023評論 1 266
  • 我被黑心中介騙來泰國打工排惨, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留吭敢,地道東北人。 一個月前我還...
    沈念sama閱讀 46,461評論 2 360
  • 正文 我出身青樓暮芭,卻偏偏與公主長得像鹿驼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子辕宏,可洞房花燭夜當晚...
    茶點故事閱讀 43,595評論 2 350

推薦閱讀更多精彩內(nèi)容