国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

PHP實現(xiàn)的二分查找算法實例分析

2024-05-05 00:01:29
字體:
來源:轉載
供稿:網友

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

二分查找法需要數(shù)組是一個有序的數(shù)組

假設我們的數(shù)組是一個遞增的數(shù)組,首先我們需要找到數(shù)組的中間位置.

一。要知道中間位置就需要知道起始位置和結束位置,然后取出中間位置的值來和我們的值做對比。
二。如果中間值大于我們的給定值,說明我們的值在中間位置之前,此時需要再次二分,因為在中間之前,所以我們需要變的值是結束位置的值,此時結束位置的值應該是我們此時的中間位置。
三。反之,如果中間值小于我們給定的值,那么說明給定值在中間位置之后,此時需要再次將后一部分的值進行二分,因為在中間值之后,所以我們需要改變的值是開始位置的值,此時開始位置的值應該是我們此時的中間位置,直到我們找到指定值。
四。或者中間值等于最初的起始位置,或結束位置(此時說明給定值未找到),下面我們來用代碼實現(xiàn)~

//循環(huán)實現(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){//如果當前要查找的值比當前數(shù)組的中間值還要打,那么意味著該值在數(shù)組的后半段//所以起始位置變成當前的middle的值,end位置不變。$start=$middle;$middle=floor(($start+$end)/2);}else{//反之$end=$middle;$middle=floor(($start+$end)/2);}}return false;}

 

//循環(huán)實現(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){//如果當前要查找的值比當前數(shù)組的中間值還要打,那么意味著該值在數(shù)組的后半段//所以起始位置變成當前的middle的值,end位置不變。$start=$middle;$middle=floor(($start+$end)/2);}else{//反之$end=$middle;$middle=floor(($start+$end)/2);}}return false;}

希望本文所述對大家PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 新建县| 新密市| 沭阳县| 桓仁| 咸宁市| 砚山县| 滁州市| 黔西县| 黎城县| 莆田市| 灵丘县| 和政县| 沾化县| 勃利县| 酉阳| 凤庆县| 镇江市| 昂仁县| 北票市| 富裕县| 岑溪市| 班玛县| 安达市| 灯塔市| 谷城县| 九龙县| 佛学| 长顺县| 永德县| 平原县| 大城县| 长武县| 垫江县| 厦门市| 改则县| 玉田县| 朝阳县| 屏东市| 山丹县| 吴堡县| 新建县|