首頁 >後端開發 >php教程 >php中二分法查找演算法實例詳解

php中二分法查找演算法實例詳解

墨辰丷
墨辰丷原創
2018-06-01 11:00:551760瀏覽

這篇文章主要介紹了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:

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:

<?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實作資料庫操作Model類別

##php實作URL加密解密

PHP foreach實作遍歷多維數組方式

以上是php中二分法查找演算法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn