本文章主要介绍了PHP实现的二分查找算法,结合实例形式分析了二分查找算法的原理与循环、递归等实现技巧,需要的朋友可以来php爱号网参考下

本文实例讲述了PHP实现的二分查找算法。分享给大家供大家参考,具体如下:
二分查找法需要数组是一个有序的数组
假设我们的数组是一个递增的数组,首先我们需要找到数组的中间位置.
一。要知道中间位置就需要知道起始位置和结束位置,然后取出中间位置的值来和我们的值做对比。
二。如果中间值大于我们的给定值,说明我们的值在中间位置之前,此时需要再次二分,因为在中间之前,所以我们需要变的值是结束位置的值,此时结束位置的值应该是我们此时的中间位置。
三。反之,如果中间值小于我们给定的值,那么说明给定值在中间位置之后,此时需要再次将后一部分的值进行二分,因为在中间值之后,所以我们需要改变的值是开始位置的值,此时开始位置的值应该是我们此时的中间位置,直到我们找到指定值。
四。或者中间值等于最初的起始位置,或结束位置(此时说明给定值未找到),下面我们来用代码实现~
//循环实现
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;
}
//循环实现
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;
}
好了以上就是PHP实现的二分查找算法实例分析示例的全部内容了,希望对你有所帮助。
-
域名劫持什么意思?域名劫持原理及实现?域名劫持怎么解决? 时间:2025-10-30 -
什么是网络协议?它包括哪些要素和内容? 时间:2025-10-30 -
简述Zookeeper的原理和作用 时间:2025-10-30 -
什么是ZooKeeper ZooKeeper是干什么的 ZooKeeper和Nacos的区别 时间:2025-10-30 -
集线器和交换机在原理,实现与使用上有哪些区别? 时间:2025-10-30 -
集线器和交换机的功能是什么?区别在哪? 时间:2025-10-30
今日更新
-
SKL币2026年价格预测 币安行情分析与投资策略指南
阅读:18
-
【SEO优化标题】
小婷是什么梗 揭秘网络热梗小婷的爆火原因和表情包出处
阅读:18
-
MANTA币2026年价格预测及欧易交易教程 项目前景分析
阅读:18
-
2026全球十大加密货币交易所排名 新手投资入门指南
阅读:18
-
狗头是什么梗?揭秘聊天神回复背后的幽默暗号,看完秒懂!
阅读:18
-
2026最佳加密货币交易平台排行 新手入门必看指南
阅读:18
-
**"摆烂娃是什么梗?揭秘年轻人躺平自嘲新潮流"**
(注:严格控制在48字内,符合百度SEO标题规范,用疑问句式吸引点击,关键词前置,突出热点话题和用户需求。)
阅读:18
-
2026年加密货币新手必选5大交易所 安全靠谱交易平台排名
阅读:18
-
重返未来3.2版本迁流的盛宴今日开启-海量活动来袭
阅读:18
-
2026年最佳虚拟币交易所排名 币圈用户必看指南
阅读:18










