PHP常用的排序和查找算法
更新時間:2015年08月06日 09:01:37 作者:soulence
這篇文章主要介紹了PHP四種基本排序算法和兩種查找算法示例,本文用一個實例講解冒泡排序法、快速排序法、選擇排序法、插入排序法的使用,需要的朋友可以參考下
本文匯總了常見的php排序算法和查找,在進行算法設(shè)計的時候有不錯的借鑒價值?,F(xiàn)分享給大家供參考之用。具體如下:
<?php
/**
* PHP最常用的四個排序方法及二種查找方法
* 下面的排序方法全部都通過測試
* auther : soulence
* date : 2015/06/20
*/
//PHP冒泡排序法
function bubbleSort(&$arr){
//這是一個中間變量
$temp=0;
//我們要把數(shù)組,從小到大排序
//外層循環(huán)
$flag=false;//這個優(yōu)化之后效率會很高,一般夠用
for($i=0;$i<count($arr)-1;$i++){
for($j=0;$j<count($arr)-1-$i;$j++){
//說明前面的數(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++){
//說明我們認(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的這個數(shù)已經(jīng)是有序
for($i=1;$i<count($arr);$i++){
//$insertVal是準(zhǔn)備插入的數(shù)
$insertVal=$arr[$i];
//準(zhǔn)備先和誰下標(biāo)為$inserIndex的比較
$inserIndex=$i-1;
//如果這個條件滿足,說明我們還沒有找到適當(dāng)?shù)奈恢?
while($inserIndex >= 0 && $insertVal < $arr[$inserIndex]){
//同時把數(shù)后移
$arr[$inserIndex+1] = $arr[$inserIndex];
$inserIndex--;
}
//插入(這時就給$inserIndex找到適當(dāng)?shù)奈恢茫?
$arr[$inserIndex+1] = $insertVal;
}
}
//快速排序法 第一種寫法 不是我實現(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);
}
/**
* 快速排序方法 第二種實現(xiàn)方法 自己實現(xiàn)的
* PHP快速排序方法
* $order asc 小到大 desc大到小 默認(rèn)是asc
* $order 的值只能為 asc desc 如果亂寫一個值也是按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;
//查詢一次,如果多次就不要這個 break;
}
}
if(!$flag){
echo "查無此數(shù)";
}
}
//調(diào)用二分查找
$arr=array(0,90,900,99990);//注意,一定要是有序的
binarySwarch($arr,90,0,count($arr)-1);
//二分查找函數(shù),它有一個前提,查找的數(shù)組必須是有序的
function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){
//如果$rightIndex < $leftIndex條件成立,說明沒有這個數(shù),則退出
if($rightIndex < $leftIndex){
echo "找不到該數(shù)";
return;
}
//首先找到中間這個數(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 "找到這個數(shù)。下標(biāo)是$middleIndex";
}
}
?>
希望本文所述排序算法和查找算法實例對大家的php程序設(shè)計有所幫助。
您可能感興趣的文章:
- 使用PHP實現(xiàn)二分查找算法代碼分享
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php二分查找二種實現(xiàn)示例
- PHP二分查找算法示例【遞歸與非遞歸方法】
- PHP二分查找算法的實現(xiàn)方法示例
- PHP實現(xiàn)的折半查找算法示例
- php數(shù)據(jù)結(jié)構(gòu)與算法(PHP描述) 查找與二分法查找
- php數(shù)據(jù)結(jié)構(gòu)之順序鏈表與鏈?zhǔn)骄€性表示例
- php線性表的入棧與出棧實例分析
- php線性表順序存儲實現(xiàn)代碼(增刪查改)
- PHP有序表查找之二分查找(折半查找)算法示例
相關(guān)文章
PHP實現(xiàn)在windows下配置sendmail并通過mail()函數(shù)發(fā)送郵件的方法
這篇文章主要介紹了PHP實現(xiàn)在windows下配置sendmail并通過mail()函數(shù)發(fā)送郵件的方法,較為詳細的分析了Windows平臺sendmail配置步驟與相應(yīng)的使用技巧,需要的朋友可以參考下2017-06-06
PHP獲取表單textarea數(shù)據(jù)中的換行問題
閑來無事,在網(wǎng)上看到一篇關(guān)于php表單轉(zhuǎn)換textarea換行符的文章,看完后,根據(jù)以往經(jīng)驗,感覺上這篇文章中的一些信息并不準(zhǔn)確...于是便自己親自對php獲取表單數(shù)據(jù)中的換行符問題進行研究2010-09-09
php實現(xiàn)圖片上傳并利用ImageMagick生成縮略圖
這篇文章主要為大家詳細介紹了php實現(xiàn)圖片上傳并利用ImageMagick生成縮略圖的相關(guān)資料,需要的朋友可以參考下2016-03-03
php中配置文件操作 如config.php文件的讀取修改等操作
對形如config.php文件的讀取,修改等操作的代碼,需要的朋友可以參考下2012-07-07

