php 二分查找函数,php如何实现二分查找

php实现二分查找的方法:首先以数组中某个值为界;然后再递归进行查找,直到结束,代码为【if ($low <= $high){$mid = intval(($low+$high)/2);if ($array[$mid] == $k)】。

d7257db8e80a1ccd89739f7b15e9d0a4.png

本教程操作环境:windows7系统、PHP5.6版,DELL G3电脑,该方法适用于所有品牌电脑。

php实现二分查找的方法:

思路:以数组中某个值为界,再递归进行查找,直到结束。

代码一<?php

function find($array, $low, $high, $k){

if ($low <= $high){

$mid = intval(($low+$high)/2);

if ($array[$mid] == $k){

return $mid;

}elseif ($k < $array[$mid]){

return find($array, $low, $mid-1, $k);

}else{

return find($array, $mid+1, $high, $k);

}

}

die('Not have...');

}

//test

$array = array(2,4,3,5);

$n = count($array);

$r = find($array,0,$n,5)

1、想最后的临界情况:第13行,return false果然是写在这里,我没有想错

2、die的用法:第13行,die终结程序相关视频推荐:PHP编程从入门到精通

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值