本文实例讲述了php中二分法查找算法实现方法。分享给大家供大家参考,具体如下:
二分法查找在高级点的开发可能会用到了,当然在大公司找工作时都会有面试题是这种了,下面我们来看一篇关于二分法查找在php中实现方法,具体的细节如下所示.
二分法(dichotomie) 即一分为二的方法,设[a,b]为R的闭区间,逐次二分法就是造出如下的区间序列([an,bn]):a0=a,b0=b,且对任一自然数n,[an+1,bn+1]或者等于[an,cn],或者等于[cn,bn],其中cn表示[an,bn]的中点.
例子1:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
header( 'Content-Type: text/html; charset=utf-8;' ); $arr = array (2,33,22,1,323,321,28,36,90,123); sort( $arr ); //二分法查找 echo $index = binarySearch( $arr ,321); function binarySearch( $arr , $key ){ $len = count ( $arr ); $mid = -1; $start = 0; $end = $len -1; while ( $start <= $end ){ $mid = (int)(( $start + $end )/2); echo $mid . "\n" ; if ( $arr [ $mid ] == $key ){ return $mid ; } else if ( $arr [ $mid ] < $key ){ $start = $mid +1; } else if ( $arr [ $mid ] > $key ){ $end = $mid -1; } } } |
例子2:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
<?php //search函数 其中$array为数组,$k为要找的值,$low为查找范围的最小键值,$high为查找范围的最大键值 function search( $array , $k , $low =0, $high =0) { if ( count ( $array )!=0 and $high == 0) //判断是否为第一次调用 { $high = count ( $array ); } if ( $low <= $high ) //如果还存在剩余的数组元素 { $mid = intval (( $low + $high )/2); //取$low和$high的中间值 if ( $array [ $mid ] == $k ) //如果找到则返回 { return $mid ; } elseif ( $k < $array [ $mid ]) //如果没有找到,则继续查找 { return search( $array , $k , $low , $mid -1); } else { return search( $array , $k , $mid +1, $high ); } } return -1; } $array = array (4,5,7,8,9,10); //测试search函数 echo search( $array , 8); //调用search函数并输出查找结果 ?> |
希望本文所述对大家PHP程序设计有所帮助。