濮阳杆衣贸易有限公司

主頁 > 知識庫 > PHP實現(xiàn)的二分查找算法實例分析

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

熱門標(biāo)簽:百度地圖標(biāo)注類型是酒店 隨州銷售電銷機(jī)器人公司 外呼系統(tǒng)人工客服 400電話申請辦理 網(wǎng)絡(luò)電話400申請 全國各省地圖標(biāo)注點 福建高頻外呼防封系統(tǒng)哪家好 商丘外呼系統(tǒng)好處 周口網(wǎng)絡(luò)回?fù)芡夂粝到y(tǒng)

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

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

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

一。要知道中間位置就需要知道起始位置和結(jié)束位置,然后取出中間位置的值來和我們的值做對比。
二。如果中間值大于我們的給定值,說明我們的值在中間位置之前,此時需要再次二分,因為在中間之前,所以我們需要變的值是結(jié)束位置的值,此時結(jié)束位置的值應(yīng)該是我們此時的中間位置。
三。反之,如果中間值小于我們給定的值,那么說明給定值在中間位置之后,此時需要再次將后一部分的值進(jìn)行二分,因為在中間值之后,所以我們需要改變的值是開始位置的值,此時開始位置的值應(yīng)該是我們此時的中間位置,直到我們找到指定值。
四?;蛘咧虚g值等于最初的起始位置,或結(jié)束位置(此時說明給定值未找到),下面我們來用代碼實現(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)
{
//如果當(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)實現(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)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

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

您可能感興趣的文章:
  • PHP有序表查找之二分查找(折半查找)算法示例
  • PHP二分查找算法的實現(xiàn)方法示例
  • php實現(xiàn)的二分查找算法示例
  • php順序查找和二分查找示例
  • PHP查找一列有序數(shù)組是否包含某值的方法

標(biāo)簽:定西 六安 南寧 佛山 樂山 海南 十堰 迪慶

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實現(xiàn)的二分查找算法實例分析》,本文關(guān)鍵詞  PHP,實現(xiàn),的,二分,查找,算法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實現(xiàn)的二分查找算法實例分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP實現(xiàn)的二分查找算法實例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    梅河口市| 湖州市| 安国市| 财经| 韩城市| 奇台县| 康乐县| 德保县| 凤阳县| 红桥区| 若尔盖县| 万年县| 宣化县| 富顺县| 辽宁省| 红河县| 佛教| 张家口市| 将乐县| 翁源县| 永福县| 寻甸| 玉树县| 盐山县| 灵石县| 淮北市| 崇礼县| 五峰| 云龙县| 宜宾市| 曲阜市| 肥乡县| 平罗县| 无棣县| 靖宇县| 拉孜县| 海安县| 兰坪| 汨罗市| 托里县| 西乌珠穆沁旗|