PHP實(shí)現(xiàn)的二分查找算法實(shí)例分析
本文實(shí)例講述了PHP實(shí)現(xiàn)的二分查找算法。分享給大家供大家參考,具體如下:
二分查找法需要數(shù)組是一個(gè)有序的數(shù)組
假設(shè)我們的數(shù)組是一個(gè)遞增的數(shù)組,首先我們需要找到數(shù)組的中間位置.
一。要知道中間位置就需要知道起始位置和結(jié)束位置,然后取出中間位置的值來(lái)和我們的值做對(duì)比。
二。如果中間值大于我們的給定值,說(shuō)明我們的值在中間位置之前,此時(shí)需要再次二分,因?yàn)樵谥虚g之前,所以我們需要變的值是結(jié)束位置的值,此時(shí)結(jié)束位置的值應(yīng)該是我們此時(shí)的中間位置。
三。反之,如果中間值小于我們給定的值,那么說(shuō)明給定值在中間位置之后,此時(shí)需要再次將后一部分的值進(jìn)行二分,因?yàn)樵谥虚g值之后,所以我們需要改變的值是開(kāi)始位置的值,此時(shí)開(kāi)始位置的值應(yīng)該是我們此時(shí)的中間位置,直到我們找到指定值。
四?;蛘咧虚g值等于最初的起始位置,或結(jié)束位置(此時(shí)說(shuō)明給定值未找到),下面我們來(lái)用代碼實(shí)現(xiàn)~
//循環(huán)實(shí)現(xiàn) function getValue($num,$arr) { //查找數(shù)組的中間位置 $length=count($arr); $start=0; $end=$length; $middle=floor(($start+$end)/2); //循環(huán)判斷 while($start>$end-1) { if($arr[middle]==$num) { return middle+1; }elseif($arr[middle]<$num) { //如果當(dāng)前要查找的值比當(dāng)前數(shù)組的中間值還要打,那么意味著該值在數(shù)組的后半段 //所以起始位置變成當(dāng)前的middle的值,end位置不變。 $start=$middle; $middle=floor(($start+$end)/2); }else{ //反之 $end=$middle; $middle=floor(($start+$end)/2); }} return false; }
//循環(huán)實(shí)現(xiàn) function getValue($num,$arr) { //查找數(shù)組的中間位置 $length=count($arr); $start=0; $end=$length; $middle=floor(($start+$end)/2); //循環(huán)判斷 while($start>$end-1) { if($arr[middle]==$num) { return middle+1; }elseif($arr[middle]<$num) { //如果當(dāng)前要查找的值比當(dāng)前數(shù)組的中間值還要打,那么意味著該值在數(shù)組的后半段 //所以起始位置變成當(dāng)前的middle的值,end位置不變。 $start=$middle; $middle=floor(($start+$end)/2); }else{ //反之 $end=$middle; $middle=floor(($start+$end)/2); }} return false; }
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
攻克CakePHP系列一 連接MySQL數(shù)據(jù)庫(kù)
請(qǐng)先參閱以前寫(xiě)的文章以便對(duì)CakePHP有所了解文章,上一篇2008-10-10PHP Ajax實(shí)現(xiàn)無(wú)刷新附件上傳
這篇文章為大家詳細(xì)主要介紹了PHP Ajax實(shí)現(xiàn)無(wú)刷新附件上傳功能的具體代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08分享一個(gè)超好用的php header下載函數(shù)
這篇文章主要為大家分享一個(gè)超好用的php header下載函數(shù),需要的朋友可以參考下2014-01-01基于PHP實(shí)現(xiàn)數(shù)據(jù)分頁(yè)顯示功能
這篇文章主要為大家詳細(xì)介紹了基于PHP實(shí)現(xiàn)數(shù)據(jù)分頁(yè)顯示功能,分頁(yè)在后臺(tái)管理中是經(jīng)常使用的功能,分頁(yè)顯示方便大量數(shù)據(jù)的管理,感興趣的小伙伴們可以參考一下2016-05-05PHP從零開(kāi)始打造自己的MVC框架之路由類(lèi)實(shí)現(xiàn)方法分析
這篇文章主要介紹了PHP從零開(kāi)始打造自己的MVC框架之路由類(lèi)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了MVC框架路由類(lèi)的原理及定義方法,需要的朋友可以參考下2019-06-06淺析使用Turck-mmcache編譯來(lái)加速、優(yōu)化PHP代碼
本篇文章是對(duì)使用Turck-mmcache編譯來(lái)加速、優(yōu)化PHP代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP圖片處理之圖片旋轉(zhuǎn)和圖片翻轉(zhuǎn)實(shí)例
這篇文章主要介紹了PHP圖片處理之圖片旋轉(zhuǎn)和圖片翻轉(zhuǎn)實(shí)例,本文使用imagerotate函數(shù)實(shí)現(xiàn),自定義了多個(gè)函數(shù)來(lái)實(shí)現(xiàn)功能需求,需要的朋友可以參考下2014-11-11