全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

PHP二分查找算法的实现方法示例

本文实例讲述了PHP二分查找算法的实现方法。分享给大家供大家参考,具体如下:

二分查找法需要数组是一个有序的数组

假设我们的数组是一个递增的数组,首先我们需要找到数组的中间位置.

1. 要知道中间位置就需要知道起始位置和结束位置,然后取出中间位置的值来和我们的值做对比。

2. 如果中间值大于我们的给定值,说明我们的值在中间位置之前,此时需要再次二分,因为在中间之前,所以我们需要变的值是结束位置的值,此时结束位置的值应该是我们此时的中间位置。

3. 反之,如果中间值小于我们给定的值,那么说明给定值在中间位置之后,此时需要再次将后一部分的值进行二分,因为在中间值之后,所以我们需要改变的值是开始位置的值,此时开始位置的值应该是我们此时的中间位置,直到我们找到指定值。

4. 或者中间值等于最初的起始位置,或结束位置(此时说明给定值未找到),下面我们来用代码实现~

//循环实现
function getValue($num,$arr)
{
  //查找数组的中间位置
  $length=count($arr);
  $start=0;
  $end=$length;
  $middle=floor(($start+$end)/2);
  //循环判断
  while($start>$end-1)
  {
    if($arr[middle]==$num)
    {
      return middle+1;
    } elseif($arr[middle]<$num)
    {
      //如果当前要查找的值比当前数组的中间值还要打,那么意味着该值在数组的后半段
      //所以起始位置变成当前的middle的值,end位置不变。
      $start=$middle;
      $middle=floor(($start+$end)/2);
    } else{
      //反之
      $end=$middle;
      $middle=floor(($start+$end)/2);
    }
  }
  return false;
}

//递归实现
/*
* 从数组中获取元素值
* @param1 int $num,要查找的目标值
* @param2 array $arr,要查找的数组
* @param3 int $start,查找的起始位置
* @param4 int $end,查找的结束位置
* @return mixed,找到了返回位置,没找到返回false
*/
function getValue4($num,$arr,$start = 0,$end = 100){
    //采用二分法查找
    $middle = floor(($end + $start) / 2);
    //判断
    if($arr[$middle] == $num){
      //已经找到了,递归的出口
      return $middle + 1;
    }elseif($arr[$middle] < $num){
      //要查找的元素在数组的后半段
      $start = $middle + 1;
      //边界值
      if($start >= $end){
        //没有找到,但是已经超出边界值,递归出口
        return false;
      }
      //调用自己去查找:递归点
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,51,100)
    }else{
      //要查找的元素在数组的前半段
      $end = $middle - 1;
      //判断边界值
      if($end < 0)return false;
      //调用自己:递归点
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,0,49)
    }
    //都没有找到
    return false;
}

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》及《php查找技巧与方法总结》

希望本文所述对大家PHP程序设计有所帮助。


# PHP  # 二分查找  # 算法  # PHP有序表查找之二分查找(折半查找)算法示例  # PHP实现的二分查找算法实例分析  # php实现的二分查找算法示例  # php顺序查找和二分查找示例  # PHP查找一列有序数组是否包含某值的方法  # 递归  # 是一个  # 定值  # 没有找到  # 程序设计  # 应该是  # 找到了  # 相关内容  # 感兴趣  # 数据结构  # 给大家  # 要知道  # 更多关于  # 所述  # 面向对象  # 来用  # 未找到  # 组中  # 半段  # 最初 


相关文章: 怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何选择建站程序?包含哪些必备功能与类型?  建站之星代理如何优化在线客服效率?  内部网站制作流程,如何建立公司内部网站?  网站制作新手教程,新手建设一个网站需要注意些什么?  深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?  建站之星2.7模板快速切换与批量管理功能操作指南  网站制作免费,什么网站能看正片电影?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  如何选择适配移动端的WAP自助建站平台?  如何快速搭建响应式可视化网站?  如何选择美橙互联多站合一建站方案?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何通过WDCP绑定主域名及创建子域名站点?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  股票网站制作软件,网上股票怎么开户?  如何选择高性价比服务器搭建个人网站?  开心动漫网站制作软件下载,十分开心动画为何停播?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  浅析上传头像示例及其注意事项  广平建站公司哪家专业可靠?如何选择?  如何在万网自助建站中设置域名及备案?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  建站之星后台管理:高效配置与模板优化提升用户体验  如何在腾讯云服务器上快速搭建个人网站?  如何用花生壳三步快速搭建专属网站?  微信h5制作网站有哪些,免费微信H5页面制作工具?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  婚礼视频制作网站,学习*后期制作的网站有哪些?  如何高效利用200m空间完成建站?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  深圳网站制作平台,深圳市做网站好的公司有哪些?  建站之星后台密码遗忘或太弱?如何重置与强化?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  ,巨量百应是干嘛的?  创业网站制作流程,创业网站可靠吗?  建站主机是什么?如何选择适合的建站主机?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  建站之星上传入口如何快速找到?  建站之星如何保障用户数据免受黑客入侵?  如何在阿里云服务器自主搭建网站?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  建站主机默认首页配置指南:核心功能与访问路径优化  如何用搬瓦工VPS快速搭建个人网站?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  建站之星如何优化SEO以实现高效排名?  如何通过山东自助建站平台快速注册域名? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。