PHP常用的排序和查找算法
本文匯總了常見的php排序算法和查找,在進(jìn)行算法設(shè)計(jì)的時(shí)候有不錯(cuò)的借鑒價(jià)值。現(xiàn)分享給大家供參考之用。具體如下:
<?php /** * PHP最常用的四個(gè)排序方法及二種查找方法 * 下面的排序方法全部都通過(guò)測(cè)試 * auther : soulence * date : 2015/06/20 */ //PHP冒泡排序法 function bubbleSort(&$arr){ //這是一個(gè)中間變量 $temp=0; //我們要把數(shù)組,從小到大排序 //外層循環(huán) $flag=false;//這個(gè)優(yōu)化之后效率會(huì)很高,一般夠用 for($i=0;$i<count($arr)-1;$i++){ for($j=0;$j<count($arr)-1-$i;$j++){ //說(shuō)明前面的數(shù)比后面的數(shù)大,就要交換 if($arr[$j]>$arr[$j+1]){ $temp=$arr[$j]; $arr[$j]=$arr[$j+1]; $arr[$j+1]=$temp; $flag=true; } } if(!$flag){ //已經(jīng)是有序了 break; } $flag=false; } } //PHP選擇排序法 效率比冒泡要高 function selectSort(&$arr){ $temp=0; for($i=0;$i<count($arr)-1;$i++){ //假設(shè)$i就是最小的數(shù) $minVal=$arr[$i]; //記錄我認(rèn)為的最小數(shù)的下標(biāo) $minIndex=$i; for($j=$i+1;$j<count($arr);$j++){ //說(shuō)明我們認(rèn)為的最小值,不是最小 if($minVal>$arr[$j]){ $minVal=$arr[$j]; $minIndex=$j; } } //最后交換 $temp=$arr[$i]; $arr[$i]=$arr[$minIndex]; $arr[$minIndex]=$temp; } } //插入排序法(小到大排序) 效率又比 選擇排序法要高一些 function insertSort(&$arr){ //先默認(rèn)下標(biāo)為0的這個(gè)數(shù)已經(jīng)是有序 for($i=1;$i<count($arr);$i++){ //$insertVal是準(zhǔn)備插入的數(shù) $insertVal=$arr[$i]; //準(zhǔn)備先和誰(shuí)下標(biāo)為$inserIndex的比較 $inserIndex=$i-1; //如果這個(gè)條件滿足,說(shuō)明我們還沒有找到適當(dāng)?shù)奈恢? while($inserIndex >= 0 && $insertVal < $arr[$inserIndex]){ //同時(shí)把數(shù)后移 $arr[$inserIndex+1] = $arr[$inserIndex]; $inserIndex--; } //插入(這時(shí)就給$inserIndex找到適當(dāng)?shù)奈恢茫? $arr[$inserIndex+1] = $insertVal; } } //快速排序法 第一種寫法 不是我實(shí)現(xiàn)的 function quickSort($left,$right,&$arr){ $l=$left; $r=$right; $pivot= $arr[($left+$right)/2]; while($l<$r){ while($arr[$l]<$pivot){ $l++; } while($arr[$r]>$pivot){ $r--; } if($l>=$r){ break; } $temp=$arr[$l]; $arr[$l]=$arr[$r]; $arr[$r]=$temp; if($arr[$l]==$pivot){ --$r; } if($arr[$r]==$pivot){ ++$l; } } if($l==$r){ $l++; $r--; } if($left<$r) quickSort($left,$r,$arr); if($right>$l) quickSort($l,$right,$arr); } /** * 快速排序方法 第二種實(shí)現(xiàn)方法 自己實(shí)現(xiàn)的 * PHP快速排序方法 * $order asc 小到大 desc大到小 默認(rèn)是asc * $order 的值只能為 asc desc 如果亂寫一個(gè)值也是按asc排序的 */ function quickSort2($arr,$order = 'asc') { if(count($arr) <= 1) return $arr; $arr_left = $arr_right = array(); $val = $arr[0];unset($arr[0]); foreach ($arr as $v) { if(strtolower($order) == 'desc'){ if($v < $val) $arr_right[] = $v; else $arr_left[] = $v; }else{ if($v > $val) $arr_right[] = $v; else $arr_left[] = $v; } } $arr_left = quickSort($arr_left,$order); $arr_right = quickSort($arr_right,$order); return array_merge($arr_left,array($val),$arr_right); } //下面是查找 $arr=array(46,90,900,0,-1); //這是按順序查詢 function search(&$arr,$findVal){ $flag=false; for($i=0;$i<count($arr);$i++){ if($findVal==$arr[$i]){ echo "找到了,下標(biāo)為=$i"; $flag=true; //查詢一次,如果多次就不要這個(gè) break; } } if(!$flag){ echo "查無(wú)此數(shù)"; } } //調(diào)用二分查找 $arr=array(0,90,900,99990);//注意,一定要是有序的 binarySwarch($arr,90,0,count($arr)-1); //二分查找函數(shù),它有一個(gè)前提,查找的數(shù)組必須是有序的 function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){ //如果$rightIndex < $leftIndex條件成立,說(shuō)明沒有這個(gè)數(shù),則退出 if($rightIndex < $leftIndex){ echo "找不到該數(shù)"; return; } //首先找到中間這個(gè)數(shù) round是出于如果出現(xiàn)小數(shù),四舍五入 $middleIndex=round(($rightIndex+$leftIndex)/2); //如果大于則向后面找 if($findVal > $arr[$middleIndex]){ binarySearch($arr,$findVal,$middleIndex+1,$rightIndex); //如果小于中間數(shù),則向前面找 }else if($findVal < $arr[$middleIndex]){ binarySearch($arr,$findVal,$leftIndex,$middleIndex-1); }else{ echo "找到這個(gè)數(shù)。下標(biāo)是$middleIndex"; } } ?>
希望本文所述排序算法和查找算法實(shí)例對(duì)大家的php程序設(shè)計(jì)有所幫助。
- 使用PHP實(shí)現(xiàn)二分查找算法代碼分享
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php二分查找二種實(shí)現(xiàn)示例
- PHP二分查找算法示例【遞歸與非遞歸方法】
- PHP二分查找算法的實(shí)現(xiàn)方法示例
- PHP實(shí)現(xiàn)的折半查找算法示例
- php數(shù)據(jù)結(jié)構(gòu)與算法(PHP描述) 查找與二分法查找
- php數(shù)據(jù)結(jié)構(gòu)之順序鏈表與鏈?zhǔn)骄€性表示例
- php線性表的入棧與出棧實(shí)例分析
- php線性表順序存儲(chǔ)實(shí)現(xiàn)代碼(增刪查改)
- PHP有序表查找之二分查找(折半查找)算法示例
相關(guān)文章
php數(shù)組保存文本與文本反編成數(shù)組實(shí)例
這篇文章主要介紹了php數(shù)組保存文本與文本反編成數(shù)組的方法,通過(guò)兩個(gè)自定義函數(shù)string2array與array2string實(shí)例展示了php數(shù)組保存文本與文本反編成數(shù)組的實(shí)現(xiàn)方法,具有不錯(cuò)的參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11PHP array_multisort()函數(shù)的使用札記
array_multisort 對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序的函數(shù),需要的朋友可以參考下。2011-07-07PHP根據(jù)文章內(nèi)容生成關(guān)鍵詞自動(dòng)化Keywords標(biāo)簽
這篇文章主要為大家介紹了PHP根據(jù)文章內(nèi)容生成關(guān)鍵詞實(shí)現(xiàn)自動(dòng)化Keywords標(biāo)簽實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12PHP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本的實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇PHP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本的實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02PHP數(shù)組常用函數(shù)實(shí)例小結(jié)
這篇文章主要介紹了PHP數(shù)組常用函數(shù),結(jié)合實(shí)例形式總結(jié)分析了php針對(duì)數(shù)組的統(tǒng)計(jì)、計(jì)算、去重、過(guò)濾等相關(guān)函數(shù)使用技巧,需要的朋友可以參考下2018-08-08隱藏X-Space個(gè)人空間下方版權(quán)方法隱藏X-Space個(gè)人空間標(biāo)題隱藏X-Space個(gè)人空間管理版權(quán)方法
隱藏X-Space個(gè)人空間下方版權(quán)方法隱藏X-Space個(gè)人空間標(biāo)題隱藏X-Space個(gè)人空間管理版權(quán)方法...2007-02-02