脚本宝典收集整理的这篇文章主要介绍了PHP实现几种经典算法详解,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
1、冒泡排序(数组排序)
function bubble_sort( $array) { $count = count( $array); if ($count <= 0 ) return false; for($i=0 ; $i<$count; $i ++){ for($j=$count-1 ; $j>$i; $j--){ if ($array[$j] < $array [$j-1]){ $tmp = $array[$j]; $array[$j] = $array[ $j-1]; $array [$j-1] = $tmp; } } } return $array; }
2、快速排序(数组排序)
function quick_sort($array ) { if (count($array) <= 1) return $array; $key = $array [0]; $left_arr = array(); $right_arr = array(); for ($i= 1; $i<count($array ); $i++){ if ($array[ $i] <= $key) $left_arr [] = $array[$i]; else $right_arr[] = $array[$i ]; } $left_arr = quick_sort($left_arr ); $right_arr = quick_sort( $right_arr); return array_merge($left_arr,array($key),$right_arr); }
3、二分查找(数组里查找某个元素)
function bin_sch($array,$low,$high,$k){ if ( $low <= $high){ $mid = intval(($low+$high)/2 ); if ($array[$mid] == $k){ return $mid; }elseif ( $k < $array[$mid]){ return bin_sch($array,$mid-1,$k); }else{ return bin_sch($array,$mid+ 1,$k); } } return -1; }
4、顺序查找(数组里查找某个元素)
function seq_sch($array,$n,$k){ $array[$n] = $k; for($i=0; $i<$n; $i++){ if( $array[$i]==$k){ break; } } if ($i<$n){ return $i; }else{ return -1; } }
以上是脚本宝典为你收集整理的PHP实现几种经典算法详解全部内容,希望文章能够帮你解决PHP实现几种经典算法详解所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。