PHP如何实现二进制搜索?(代码示例)

PHP如何实现二进制搜索?(代码示例)

内容导读

收集整理的这篇技术教程文章主要介绍了PHP如何实现二进制搜索?(代码示例),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2054字,纯文字阅读大概需要3分钟

内容图文

二进制搜索(折半查找)是一种用于搜索排序数组中元素的搜索技术。那么PHP中如何实现二进制搜索?下面本篇文章就来给大家介绍在PHP中如何使用迭代和递归方式来实现二进制搜索,希望对大家有所帮助。【视频教程推荐:PHP教程】

方法一:使用迭代

步骤:

1、对数组进行排序,因为二进制搜索仅适用于已排序的范围

2、如果我们要搜索的元素大于右侧的中间元素搜索,则计算中间元素,否则计算左侧的搜索。

3、如果找到元素,则返回True。

实现代码:

<?php header("content-type:text/html;charset=utf-8");function binarySearch(Array $arr, $x) {

 // check for empty array

 if (count($arr) === 0) return false;

 $low = 0;

 $high = count($arr) - 1;




 while ($low <= $high) {








 // 计算中间索引



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





// 在中间找到元素



if($arr[$mid] == $x) {





 return true;



 }




 if ($x < $arr[$mid]) {





 // 搜索数组的左侧





$high = $mid -1;



 }



 else {





 // 搜索数组的右侧





$low = $mid + 1;



 }

 }




 // 元素x不存在,返回false

return false; }
 $arr = array(1, 2, 3, 4, 5); $value = 5; if(binarySearch($arr, $value) == true) {

 echo "元素".$value.": 存在"; } else {

 echo "元素".$value.": 不存在"; } ?>

输出:

元素5: 存在

方法二:使用递归

递归是我们重复调用相同函数直到匹配基本条件以结束递归的方式。原理和方法一相同,只需以递归的方式更改函数的参数并分解问题。

实现代码:

<?php header("content-type:text/html;charset=utf-8");function binarySearch(Array $arr, $start, $end, $x){

 if ($end < $start)



 return false;



$mid = floor(($end + $start)/2);

 if ($arr[$mid] == $x)




return true;


 elseif ($arr[$mid] > $x) {




 // 调用binarySearch()函数本身, 改变其中参数:$start, $mid-1



return binarySearch($arr, $start, $mid - 1, $x);

 }

 else {




 // 调用binarySearch()函数本身, 改变其中参数:mid + 1, end



return binarySearch($arr, $mid + 1, $end, $x);

 } }
 $arr = array(1, 2, 3, 4, 5); $value = 6; if(binarySearch($arr, 0, count($arr) - 1, $value) == true) {

 echo "元素".$value.": 存在"; } else {

 echo "元素".$value.": 不存在"; } ?>

输出:

元素6: 不存在

以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注Gxl网相关教程栏目!!!

以上就是PHP如何实现二进制搜索?(代码示例)的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的PHP如何实现二进制搜索?(代码示例)全部内容,希望文章能够帮你解决PHP如何实现二进制搜索?(代码示例)所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com