PHP练习-二分查找算法

2018-08-24 23:00 By "Powerless" 3471 0 1

/**
 * 二分查找,要求数组已经排好顺序
 * @param  array $array 数组
 * @param  int $low   数组起始元素下标
 * @param  int $high  数组末尾元素下标
 * @param   $k     要查找的元素
 * @return mixed        成功时返回数组下标,失败返回-1
 */
function binSch($array,$low,$high,$k){
    if ($low <= $high) {
        $mid = intval(($low + $high) / 2);
        if ($array[$mid] == $k) {
            return $mid;
        } elseif ($k < $array[$mid]) {
            return binSch($array,$low,$mid - 1,$k);
        } else{
            return binSch($array,$mid + 1,$high,$k);
        }
    }
    return -1;
}

// 测试:二分查找
$arr2 = array(5,9,15,25,34,47,55,76);
echo binSch($arr2,0,7,47);//结果为5


评 论

Others Discussion

  • 分布式服务限流
    Posted on 2020-02-07 18:57
  • 有状态服务VS无状态服务
    Posted on 2020-02-07 18:18
  • 企业级PAAS云平台几个关键问题和挑战
    Posted on 2019-06-12 18:33
  • MySQL 单库后期分库策略
    Posted on 2019-08-19 14:31
  • Redis七大经典问题
    Posted on 2021-05-27 11:14
  • 关于HTTPS的五大误区
    Posted on 2020-02-02 01:10
  • PHP实现精确发布时间
    Posted on 2018-12-06 21:00
  • 为什么要测量尾部延迟
    Posted on 2020-09-18 10:34