欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP二分查找算法示例【遞歸與非遞歸方法】

 更新時(shí)間:2016年09月29日 08:50:27   作者:ligbee  
這篇文章主要介紹了PHP二分查找算法,結(jié)合實(shí)例形式分析了php基于遞歸與非遞歸方法實(shí)現(xiàn)二分查找的具體操作技巧,需要的朋友可以參考下

本文實(shí)例講述了PHP二分查找算法。分享給大家供大家參考,具體如下:

binarySearch

二分查找采用的方法比較容易理解,以數(shù)組為例:

① 先取數(shù)組中間的值floor((low+top)/2),

② 然后通過與所需查找的數(shù)字進(jìn)行比較,若比中間值大,則將首值替換為中間位置下一個(gè)位置,繼續(xù)第一步的操作;若比中間值小,則將尾值替換為中間位置上一個(gè)位置,繼續(xù)第一步操作

③ 重復(fù)第二步操作直至找出目標(biāo)數(shù)字

比如從1,3,9,23,54 中查找數(shù)字23,

首位置為0, 尾位置為4,中間位置就為2 值為9,比23小,則首位置更新為2+1即3;那么接下來中間位置就為(3+4)/2=3,值為23,比較相等即找到

//  非遞歸算法:
//  $target是要查找的目標(biāo) $arr是已經(jīng)排序好的數(shù)組
function binary(&$arr,$low,$top,$target){
    while($low <= $top){
//由于php取商是有小數(shù)的,所以向下取整,不過也可不加,數(shù)組也會(huì)取整
      $mid = floor(($low+$top)/2);
      echo $mid."<br>";
      if($arr[$mid]==$target){
        return $arr[$mid];
      }elseif($arr[$mid]<$target){
        $low = $mid+1;
      }else{
        $top = $mid-1;
      }
    }
    return -1;
}

//  遞歸算法:
function binaryRecursive(&$arr,$low,$top,$target){
    if($low<=$top){
      $mid = floor(($low+$top)/2);
      if($mid==$target){
        return $arr[$mid];
      }elseif($arr[$mid]<$target){
        return binaryRecursive($arr,$mid+1,$top,$target);
      }else{
        return binaryRecursive($arr,$low,$top-1,$target);
      }
    }else{
      return -1;
    }
}

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php查找技巧與方法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php加密方法總結(jié)》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php正則表達(dá)式用法總結(jié)》、及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Linux系統(tǒng)下使用XHProf和XHGui分析PHP運(yùn)行性能

    Linux系統(tǒng)下使用XHProf和XHGui分析PHP運(yùn)行性能

    這篇文章主要介紹了Linux系統(tǒng)下使用XHProf和XHGui分析PHP運(yùn)行性能的方法,該方案支持Apache與Nginx服務(wù)器及多種數(shù)據(jù)庫環(huán)境,需要的朋友可以參考下
    2015-12-12
  • 淺談php中mysql與mysqli的區(qū)別分析

    淺談php中mysql與mysqli的區(qū)別分析

    本篇文章是對(duì)php中mysql與mysqli的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • ThinkPHP防止SQL注入攻擊的方法

    ThinkPHP防止SQL注入攻擊的方法

    在ThinkPHP中,參數(shù)綁定是一種安全的方式,用于處理用戶輸入,特別是在構(gòu)建數(shù)據(jù)庫查詢時(shí),參數(shù)綁定可以防止SQL注入攻擊,所以本文將給大家介紹了ThinkPHP防止SQL注入攻擊的方法,需要的朋友可以參考下
    2023-12-12
  • php 上傳功能實(shí)例代碼

    php 上傳功能實(shí)例代碼

    php 上傳功能實(shí)例代碼,需要的朋友可以參考下。
    2010-04-04
  • PHP+shell實(shí)現(xiàn)多線程的方法

    PHP+shell實(shí)現(xiàn)多線程的方法

    這篇文章主要介紹了PHP+shell實(shí)現(xiàn)多線程的方法,實(shí)例分析了php實(shí)現(xiàn)多線程的相關(guān)技巧,需要的朋友可以參考下
    2015-07-07
  • php中隨機(jī)函數(shù)mt_rand()與rand()性能對(duì)比分析

    php中隨機(jī)函數(shù)mt_rand()與rand()性能對(duì)比分析

    這篇文章主要介紹了php中隨機(jī)函數(shù)mt_rand()與rand()性能對(duì)比分析,較為詳細(xì)的分析了兩個(gè)函數(shù)的具體用法,并以實(shí)例形式分析了在不同平臺(tái)下的運(yùn)行效率問題,需要的朋友可以參考下
    2014-12-12
  • PHP計(jì)算日期相差天數(shù)實(shí)例分析

    PHP計(jì)算日期相差天數(shù)實(shí)例分析

    這篇文章主要介紹了PHP計(jì)算日期相差天數(shù)的方法,結(jié)合實(shí)例形式分析了PHP日期與時(shí)間操作及換算的相關(guān)技巧,需要的朋友可以參考下
    2016-02-02
  • php基于自定義函數(shù)記錄log日志方法

    php基于自定義函數(shù)記錄log日志方法

    這篇文章主要介紹了php基于自定義函數(shù)記錄log日志方法,涉及php針對(duì)文件、目錄及錯(cuò)誤日志相關(guān)操作技巧,需要的朋友可以參考下
    2017-07-07
  • php 無限級(jí)分類 獲取頂級(jí)分類ID

    php 無限級(jí)分類 獲取頂級(jí)分類ID

    這篇文章主要介紹了php 無限級(jí)分類 獲取頂級(jí)分類ID的相關(guān)代碼,需要的朋友可以參考下
    2016-03-03
  • PHP的命令行擴(kuò)展Readline相關(guān)函數(shù)的使用

    PHP的命令行擴(kuò)展Readline相關(guān)函數(shù)的使用

    PHP 作為一個(gè) Web 開發(fā)語言,相對(duì)來說,命令行程序并不是它的主戰(zhàn)場(chǎng)。所以很多年輕的 PHP 開發(fā)者可能連命令行腳本都沒有寫過,更別提交互式的命令操作了。而今天,我們帶來的這個(gè)擴(kuò)展就是針對(duì) PHP 的交互式命令行操作的
    2021-05-05

最新評(píng)論