PHP实现的二分查找算法实例分析示例
本文章主要介绍了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实现的二分查找算法实例分析示例的全部内容了,希望对你有所帮助。
-
Web3 安全入门避坑指南(钱包被恶意多签风险分析) 时间:2025-04-30
-
比特币隔离钱包是什么?比特币隔离钱包有什么好处? 时间:2025-04-30
-
多重签名钱包是什么意思?多重签名钱包地址如何恢复? 时间:2025-04-30
-
MetaMask充值/提现/Swap/添加地址流程 时间:2025-04-30
-
什么是BTC 钱包?了解其定义、类型和用法 时间:2025-04-30
-
Rabby 与 MetaMask:哪个是更好的加密钱包? 时间:2025-04-30
今日更新
-
PHP实现生成模糊图片的操作讲解
阅读:25
-
php获取微信共享收货地址的方法教程
阅读:29
-
php实现socket推送技术的讲解
阅读:26
-
PHP实现的最大正向匹配算法样例
阅读:23
-
PHP实现的字符串匹配算法示例
阅读:25
-
PHP递归法实现的快速排序示例演示
阅读:24
-
php实现自定义截取中文字符串-utf8版
阅读:25
-
PHP实现读取XML格式文件的方法教程
阅读:28
-
php读取目录及子目录下所有文件名的具体操作方法
阅读:24
-
PHP实现批量修改文件名称的方法教程
阅读:24