您现在的位置是:首页 > PHP技术PHP技术
php中使用二分法查找某个值
2017-08-10【PHP技术】2332 人已围观
简介 经常在QQ的PHP技术群里看到有人讨论PHP面试的话题,PHP的二分法出现频率很高,今天我们来说说PHP二分法的实现例子 已知一个数...
经常在QQ的PHP技术群里看到有人讨论PHP面试的话题,PHP的二分法出现频率很高,今天我们来说说PHP二分法的实现例子
已知一个数组里包含N个数字,使用二分法查出该数据
//声明一个数组
$data = [2,3,4,5];
//获取数组长度
$len = count($data)-1;
2.开始实现代码
/**
* @param $start 开始位置
* @param $len 数组长度
* @param $data 要查询的数组
* @param $value 要查询的值
* @return bool|float 成功返回查询到的值,否则返回false
*/
function search($start, $len, $data,$search)
{
while($start <= $len )
{
$mid = floor(($start + $len)/2);
if($data[$mid] == $search){
return $mid;
}elseif ($data[$mid] < $search){
$start = $mid+1;
}else{
$len = $mid-1;
}
}
return false;
}
3.调用方法查找值为5的
echo search(0, $len, $data,5);
输出结果为:3
关注宁波网站建设博客,更多精彩分享,敬请期待!
Tags:
很赞哦! ()
相关文章
随机图文
mysql常见的多表查询语句
select*fromTable1,Table2whereTable1.id=1andTbale2.id-2(是某一相同字段)注意这样的查询...
dedecms通过增加自定义属性达到文章分类的效果
dedecms是个功能强大的网站管理系统,殷雯工作室开发网站功能时有学习他们功能的思想。今天来研究一下dedecms的文章附加属性功能。...
ThinkPHP6.0RC2版本发布啦
一早打开网站看到ThinkPHP6.0RC2版本发布——架构升级、精简核心! 厉害,学的比开发的还要慢! 我们在刚适应从tp3.X到tp5....
高级php程序员需要具备的技能
有网友问高级PHP程序员需要具备哪些技能,应该怎么学习?殷雯小编认为初级的php程序员具备开发和前端。高级的程序员应该是开发+前端+运维。既...




微信收款码
支付宝收款码