婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP折半(二分)查找算法實(shí)例分析

PHP折半(二分)查找算法實(shí)例分析

熱門標(biāo)簽:遼寧ai電銷機(jī)器人價格 寧波外呼營銷系統(tǒng) 地圖標(biāo)注專員怎么樣 長沙做地圖標(biāo)注公司 四川保險智能外呼系統(tǒng)供應(yīng)商 福建銀行智能外呼系統(tǒng)價格 房產(chǎn)中介用的是什么外呼系統(tǒng) 電話機(jī)器人銷售主要負(fù)責(zé)什么 上海做外呼線路的通信公司

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

折半查詢只適用于已經(jīng)按照正序或者逆序排序的數(shù)組,字符串等;

算法:

先取數(shù)組的中間位置,無中間位置,則向下取整;

從中間進(jìn)行折半,大小判斷,進(jìn)入前半段或者后半段;

再對前半段或者后半段進(jìn)行同樣的折半查詢,

直到查詢到匹配的字符,才停止(本例用break,如果置于函數(shù)中,return即可)

php實(shí)現(xiàn)的代碼如下:

?php
$arr = array(1,2,3,4,5,6,7,8,9,10);//數(shù)組
$key = 4;//要查詢的關(guān)鍵字
$low = 0;//開始位的標(biāo)志
$high = count($arr);//終止位的標(biāo)志
while($low = $high){//查詢開始結(jié)束的條件
 $mid = floor(($low + $high)/2);//進(jìn)行中間位置計算,向下取整
 if($arr[$mid] == $key){//查詢成功
 echo $arr[$mid];
 break;//結(jié)束本頁執(zhí)行,函數(shù)可用return
 }elseif($arr[$mid] > $key){ //查詢前半段,把結(jié)束標(biāo)志移到中間位置前一位
 $high = $mid - 1;
 }else{ //查詢后半段,把開始位置移到中間位置的后一位
 $low = $mid + 1;
 }
}
/*
運(yùn)行結(jié)果:4
*/
?>

補(bǔ)充:折半(二分)查找算法類:

/**
 * Description:php實(shí)現(xiàn)二分查找算法的類
 * @author wzy
 */
class binary_search{
  public $arr;
  public $key;
  function __construct($arr,$key){
    //這里初始化的數(shù)組已經(jīng)是有序數(shù)組
    $this->arr=$arr;
    $this->key=$key;
  }
  function binarysearch(){
    $start=0;
    $end=count($this->arr)-1;
    while($start=$end){
      //mid的取值可以為上整數(shù)或者下整數(shù)
      $mid=ceil(($start+$end)/2);
      //$mid=($start+$end)>>1;
      //$mid=intval(($start+$end)/2);
      if($this->arr[$mid]$this->key){
        $start=$mid+1;
      }else if($this->arr[$mid]>$this->key){
        $end=$mid-1;
      }else{
        return $mid;
      }
    }
  }
}

可能大家還會遇到這種情況,數(shù)組中的元素有重復(fù)數(shù)據(jù),需要返回的是重復(fù)數(shù)據(jù)中的第一個元素的位置,例如

$arr=array(1,2,3,4,5,6,6,6,6,7,8);

查找6這個元素時返回的位置應(yīng)該為5,而不是其他(下標(biāo)從0開始計數(shù)),這樣需要在返回的mid進(jìn)行判斷,代碼如下:

/**
 * Description:php實(shí)現(xiàn)二分查找算法的類
 * @author wzy
 */
class binary_search{
  public $arr;
  public $key;
  function __construct($arr,$key){
    //這里初始化的數(shù)組已經(jīng)是有序數(shù)組
    $this->arr=$arr;
    $this->key=$key;
  }
  function binarysearch(){
    $start=0;
    $end=count($this->arr)-1;
    while($start=$end){
      //mid的取值可以為上整數(shù)或者下整數(shù)
      $mid=ceil(($start+$end)/2);
      //$mid=($start+$end)>>1;
      //$mid=intval(($start+$end)/2);
      if($this->arr[$mid]$this->key){
        $start=$mid+1;
      }else if($this->arr[$mid]>$this->key){
        $end=$mid-1;
      }else{
        //返回第一個匹配的元素
        for($i=$mid-1;$i>=0;$i--){
          if($this->arr[$i]==$this->key){
            $mid=$i;
          }else{
            break;
          }
        }
        return $mid;
      }
    }
  }
}

更多關(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實(shí)現(xiàn)的折半查找算法示例
  • PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
  • php二分查找二種實(shí)現(xiàn)示例
  • php順序查找和二分查找示例
  • php數(shù)據(jù)結(jié)構(gòu)與算法(PHP描述) 查找與二分法查找
  • 解析php二分法查找數(shù)組是否包含某一元素
  • PHP二分查找算法示例【遞歸與非遞歸方法】
  • PHP二分查找算法的實(shí)現(xiàn)方法示例
  • PHP基于二分法實(shí)現(xiàn)數(shù)組查找功能示例【循環(huán)與遞歸算法】
  • PHP實(shí)現(xiàn)的二分查找算法實(shí)例分析

標(biāo)簽:常德 宿遷 澳門 宜春 工商登記 深圳 佛山 延安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP折半(二分)查找算法實(shí)例分析》,本文關(guān)鍵詞  PHP,折半,二分,查找,算法,;如發(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折半(二分)查找算法實(shí)例分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP折半(二分)查找算法實(shí)例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲人亚洲人成电影网站色| 精品亚洲免费视频| 欧美久久久一区| 99在线精品观看| 欧美大片在线观看| 精品久久久久久久久久久久久久久 | 美腿丝袜一区二区三区| 麻豆国产精品视频| 美女视频黄频大全不卡视频在线播放| 国产福利一区二区| 日本aⅴ免费视频一区二区三区| 国产日韩欧美不卡在线| 亚洲午夜久久久久中文字幕久| 在线亚洲精品福利网址导航| 91视视频在线直接观看在线看网页在线看| 丁香六月久久综合狠狠色| 99热在这里有精品免费| 欧美日韩大陆一区二区| 欧美日韩一区 二区 三区 久久精品 | 激情欧美一区二区三区在线观看| 亚洲欧美日韩国产手机在线 | 天堂精品中文字幕在线| 久久国产乱子精品免费女| 不卡的av中国片| 在线电影一区二区三区| 中文字幕日韩精品一区| 亚洲欧美综合另类在线卡通| 日韩精品亚洲一区| 国产资源精品在线观看| 美女看a上一区| 9191国产精品| 亚洲精品免费在线| 麻豆成人在线观看| 欧美精品一区二区三区久久久| 欧美r级在线观看| 国内精品久久久久影院薰衣草| 中文字幕不卡一区| 欧美日韩高清不卡| 92国产精品观看| 欧美狂野另类xxxxoooo| 亚洲福利电影网| 精品国产123| 日韩一区二区电影| 久久精品一区二区三区四区| 欧美日韩亚洲不卡| 欧美精品 国产精品| 国产欧美日韩视频一区二区| 日韩精品影音先锋| 久久国产尿小便嘘嘘| 琪琪久久久久日韩精品| 青娱乐精品视频在线| 麻豆专区一区二区三区四区五区| 亚洲高清三级视频| 久久er精品视频| 国产v综合v亚洲欧| 91官网在线观看| 日韩一级免费观看| 国产精品综合二区| 粉嫩欧美一区二区三区高清影视| 成人小视频在线| 在线亚洲高清视频| 日韩欧美一二三区| 国产精品每日更新| 国产精品综合在线视频| 午夜日韩在线电影| 国产盗摄一区二区| 91久久免费观看| 精品盗摄一区二区三区| 日韩精品一区二区三区老鸭窝| 久久久精品免费网站| 久久久久久一二三区| 一区二区高清视频在线观看| 夜夜揉揉日日人人青青一国产精品| 五月开心婷婷久久| 国内精品视频666| 9i看片成人免费高清| 欧美三区在线视频| 亚洲韩国一区二区三区| 国产成人一级电影| 欧美精品自拍偷拍| 成人av资源站| 欧美一区二区免费视频| 成人福利视频网站| 在线成人av影院| 一区二区三区中文字幕| 另类小说一区二区三区| 欧美自拍丝袜亚洲| 亚洲欧美日韩国产中文在线| 精品中文字幕一区二区小辣椒| 欧美图区在线视频| 亚洲一区二区三区视频在线| 色综合天天综合在线视频| 综合久久一区二区三区| 91在线看国产| 一级女性全黄久久生活片免费| 日本乱码高清不卡字幕| 1区2区3区精品视频| 成人黄色av电影| 国产精品国产a级| 欧美午夜一区二区三区 | 久久噜噜亚洲综合| 黄色资源网久久资源365| 91精品国产麻豆国产自产在线| 亚洲日本在线观看| 欧洲一区在线观看| 亚洲成人先锋电影| 69p69国产精品| 国产在线视视频有精品| 国产精品美女久久久久久久久久久| 成人app在线| 五月综合激情网| 丝袜诱惑亚洲看片| 日本一区二区三级电影在线观看 | 日韩女优av电影| 欧美日韩精品久久久| 日韩电影一区二区三区| 国产亚洲欧美中文| 99久久精品国产一区二区三区| 亚洲图片欧美视频| 亚洲欧美日韩一区二区| www国产成人| 欧美丰满一区二区免费视频 | 国产精品18久久久久久久网站| 亚洲视频一区在线观看| 久久久久一区二区三区四区| 欧美女孩性生活视频| 成人av在线电影| 成熟亚洲日本毛茸茸凸凹| 六月丁香婷婷久久| 久久99精品久久只有精品| 免费日韩伦理电影| 午夜欧美在线一二页| 亚洲一区在线观看免费观看电影高清| 亚洲一级二级在线| 欧美经典三级视频一区二区三区| 日韩欧美久久久| 日韩一区二区在线观看| 日韩欧美在线一区二区三区| 欧美一区在线视频| 日韩女同互慰一区二区| 中文字幕欧美国产| 亚洲精品ww久久久久久p站| 亚洲制服丝袜av| 精品一区二区在线免费观看| 成人综合在线网站| 欧美一级免费观看| 最新国产精品久久精品| 五月天视频一区| 国产一区二三区| 欧美亚洲国产一区二区三区va| 欧美美女网站色| 久久综合99re88久久爱| 亚洲男同性恋视频| 激情五月播播久久久精品| 91色porny| 久久久91精品国产一区二区精品| 国产精品萝li| 激情五月婷婷综合网| 91黄色在线观看| 日韩午夜精品电影| 尤物在线观看一区| 国产一区二区三区综合| 正在播放一区二区| 亚洲免费伊人电影| 九色porny丨国产精品| 91黄色免费观看| 中文字幕av一区二区三区高 | 成人av网址在线| 精品不卡在线视频| 日本不卡的三区四区五区| 91久久精品日日躁夜夜躁欧美| 久久综合九色综合欧美98| 亚洲va欧美va人人爽午夜| 91美女片黄在线观看91美女| 国产精品久久久久久久岛一牛影视| 亚洲图片欧美综合| 精品视频一区二区不卡| 亚洲国产成人av网| 欧美日韩激情一区二区三区| 亚洲伦理在线免费看| 色婷婷亚洲综合| 午夜视频在线观看一区二区| 欧美丝袜丝交足nylons图片| 亚洲自拍偷拍麻豆| 制服丝袜亚洲色图| 久久99精品国产91久久来源| 久久久精品中文字幕麻豆发布| 国产精品亚洲午夜一区二区三区| 欧美日韩色综合| 18成人在线观看| 洋洋av久久久久久久一区| 欧美久久久影院| 激情六月婷婷久久| 中文一区在线播放| 色婷婷av久久久久久久| 轻轻草成人在线| 亚洲日本电影在线| 精品久久99ma| 91高清视频免费看| 国产乱色国产精品免费视频|