博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP的几种排序方法
阅读量:4364 次
发布时间:2019-06-07

本文共 2619 字,大约阅读时间需要 8 分钟。

$arr[$j+1]){ $temp=$arr[$j]; $arr[$j]=$arr[$j+1]; $arr[$j+1]=$temp; $flag=true; } } if(!$flag){ //已经是有序了 break; } $flag=false; }} //PHP选择排序法 效率比冒泡要高function selectSort(&$arr){ $temp=0; for($i=0;$i
$arr[$j]){ $minVal=$arr[$j]; $minIndex=$j; } } //最后交换 $temp=$arr[$i]; $arr[$i]=$arr[$minIndex]; $arr[$minIndex]=$temp; }} //插入排序法(小到大排序) 效率又比 选择排序法要高一些function insertSort(&$arr){ //先默认下标为0的这个数已经是有序 for($i=1;$i
= 0 && $insertVal < $arr[$inserIndex]){ //同时把数后移 $arr[$inserIndex+1] = $arr[$inserIndex]; $inserIndex--; } //插入(这时就给$inserIndex找到适当的位置) $arr[$inserIndex+1] = $insertVal; }} //快速排序法 第一种写法 不是我实现的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);} /** * 快速排序方法 第二种实现方法 自己实现的 * PHP快速排序方法 * $order asc 小到大 desc大到小 默认是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
$arr[$middleIndex]){ binarySearch($arr,$findVal,$middleIndex+1,$rightIndex); //如果小于中间数,则向前面找 }else if($findVal < $arr[$middleIndex]){ binarySearch($arr,$findVal,$leftIndex,$middleIndex-1); }else{ echo "找到这个数。下标是$middleIndex"; }} ?>

 

转载于:https://www.cnblogs.com/sweet521/p/6140701.html

你可能感兴趣的文章
C语言中格式化输出,四舍五入类型问题
查看>>
ListView
查看>>
WPF浏览器应用程序与JS的互调用(不用WebBrowser)
查看>>
bzoj2820: YY的GCD
查看>>
链表后续完善(一)
查看>>
Netsharp快速入门(之13) 销售管理(单据流转 销售订单生成发货单)
查看>>
郑州大学2018新生训练赛第十场题解
查看>>
相关子查询和嵌套子查询
查看>>
Oracle分析函数入门
查看>>
线段拟合(带拉格朗日乘子,HGL)
查看>>
oracle数据库服务介绍
查看>>
SQL存储过程分页实现
查看>>
Oracle 11gR2 deferred segment creation 与 exp/imp 说明
查看>>
java基础知识系列--- 反射,注解,泛型,内省
查看>>
Android adb的使用
查看>>
Ubuntu18.04 + cuda9.0+cudnn7.0
查看>>
CF484E Sign on Fence
查看>>
mybatis的二级缓存的使用
查看>>
cd命令
查看>>
Uvalive6885(最短路)
查看>>