php二分查找二种实现示例

yizhihongxing

PHP二分查找的实现

什么是二分查找算法?

二分查找,也称折半查找,是一种在有序数组中查找某一特定元素的搜索算法。它将目标值与数组中间位置的元素进行比较,如比中间位置的元素大,则目标值在数组的左半部分;如比中间位置的元素小,则目标值在数组的右半部分。不停地二分数组,直到找到目标值为止。通过这种方式,能够快速地找到特定元素,提高搜索效率。

二分查找算法在PHP中的实现

示例一

以下是在PHP中实现的基本二分查找算法:

/**
 * @param array $arr 有序数组
 * @param int $key 查找值
 * @return bool|int 返回查找值的下标,未找到则返回false
 */
function binary_search(array $arr, int $key)
{
    $low = 0; // 查找范围起点下标
    $high = count($arr) - 1; // 查找范围终点下标

    while ($low <= $high) {
        $mid = intval(($low + $high) / 2); // 中间下标

        if ($key === $arr[$mid]) {
            return $mid;
        }

        if ($key < $arr[$mid]) {
            $high = $mid - 1;
        } else {
            $low = $mid + 1;
        }
    }

    return false; //未找到
}

上述代码中的参数说明如下:

array $arr:要查找的有序数组

int $key:要查找的值

这段代码中,我们使用 while 循环来实现二分查找。首先确定要查找的范围,即查找起点和查找终点的下标。接着,计算出中间下标,与查找值进行比较。如果相等,则说明已经找到了目标值,返回它的下标。如果查找值小于中间值,则目标值在数组的左半部分,修改查找终点下标为中间下标减1,继续寻找。如果查找值大于中间值,则目标值在数组的右半部分,修改查找起点下标为中间下标加1,继续寻找。当查找起点下标大于查找终点下标时,表示已经遍历整个有序数组,未找到目标值,返回false。

示例二

以下是递归方式实现的PHP二分查找算法:

/**
 * @param array $arr 有序数组
 * @param int $low 查找起点下标
 * @param int $high 查找终点下标
 * @param int $key 查找值
 * @return bool|int 返回查找值的下标,未找到则返回false
 */
function binary_search_recursive(array $arr, int $low, int $high, int $key)
{
    if ($low <= $high) {
        $mid = intval(($low + $high) / 2); // 中间下标

        if ($key === $arr[$mid]) {
            return $mid;
        }

        if ($key < $arr[$mid]) {
            return binary_search_recursive($arr, $low, $mid - 1, $key);
        } else {
            return binary_search_recursive($arr, $mid + 1, $high, $key);
        }
    }

    return false; // 未找到
}

上述代码中的参数说明如下:

array $arr:要查找的有序数组

int $low:要查找范围的起点下标

int $high:要查找范围的终点下标

int $key:要查找的值

这段代码中,我们使用递归函数来实现二分查找。递归函数的实现方式与 while 循环方式类似,递归结束的条件为查找起点下标大于查找终点下标。递归函数中的变量同样需要在递归时进行传递。

总结

在PHP中,二分查找算法是提高搜索效率的重要算法之一。我们可以使用 while 循环或递归函数来实现二分查找算法。以上是两种不同实现方式的示例,使用者可以在实现时按照自身的需要进行修改和优化。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:php二分查找二种实现示例 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • 深入PHP异步执行的详解

    深入PHP异步执行的详解 什么是异步执行 异步执行是指某一段代码可以在原有代码流程中独立运行,不影响其他代码的执行流程,可以提高程序的性能和效率。 PHP异步执行的方式 异步执行方式一:多进程 多进程可以通过pcntl、posix等扩展进行实现。使用这种方式需要注意以下几点: 需要在操作系统级别创建新的进程,这会占用一定的系统资源。 子进程需要向父进程发送进…

    PHP 2023年5月26日
    00
  • PHP goto语句简介和使用实例

    PHP goto语句简介和使用实例 简介 goto语句是一种跳转语句,它能够使程序跳转到代码中的其他位置,而不受正常执行顺序的限制。在PHP中,可以使用goto语句来实现类似于C语言中的switch语句的效果,或者用于简化一些复杂嵌套条件语句的代码。 使用goto语句时,需要注意以下几点: 应该避免在代码中过度使用goto语句,否则会导致代码的可读性和可维护…

    PHP 2023年5月30日
    00
  • PHP生成自定义长度随机字符串的函数分享

    生成自定义长度随机字符串是Web开发中常用的功能之一。以下是使用PHP语言实现生成自定义长度随机字符串的函数的完整攻略。 实现思路 实现生成指定长度的随机字符串可以采用以下思路: 定义一个包含所有可用字符的字符串; 在字符串中随机选取指定长度的字符。 生成代码 下面是生成指定长度的随机字符串的PHP代码: function generateRandomStr…

    PHP 2023年5月26日
    00
  • PHP创建对象的六种方式实例总结

    PHP创建对象的六种方式实例总结 在PHP中,我们常常需要创建对象,使用对象完成各种需求。本文将介绍创建对象的六种方式,并提供相应的示例代码。 1. 通过new关键字创建对象 我们可以通过new关键字创建一个对象。在使用new关键字时,我们需要指定要创建的对象的类名,并可选地向该类的构造函数传递参数。 示例代码: class Person { private…

    PHP 2023年5月23日
    00
  • 微信小程序保存多张图片的实现方法

    讲解“微信小程序保存多张图片的实现方法”的攻略如下: 一、保存单张图片 在微信小程序中,保存单张图片需要借助wx.getImageInfo接口获取图片信息和wx.saveImageToPhotosAlbum接口保存图片到相册。 步骤如下: 获取图片信息:使用wx.getImageInfo接口获取图片信息,包括图片的本地路径和宽高等信息。 javascript…

    PHP 2023年5月30日
    00
  • php合并数组中相同元素的方法

    当我们需要将多个数组合并成一个数组时,若出现了相同的元素,我们可以使用PHP中的合并函数array_merge来进行数组合并。但是,若需要将相同的元素进行合并,我们可以使用PHP中的另一个函数array_merge_recursive来实现。 以下是详细的攻略过程: 准备工作 在进行数组相同元素合并的操作前,我们需要先在PHP中准备好相关的数组数据。下面用两…

    PHP 2023年5月26日
    00
  • PHP文件操作实现代码分享

    下面是关于”PHP 文件操作实现代码分享”的完整攻略。 1. 文件操作概述 在 PHP 中,通过文件操作函数可以实现对文件的创建、打开、读写和关闭等操作。使用这些函数可以轻松实现文件的管理,可以用于创建用户日志、数据备份、文件上传、图片裁剪等。 2. 文件操作的常用函数 以下为 PHP 中文件操作的常用函数: fopen() – 打开文件或 URL fwri…

    PHP 2023年5月23日
    00
  • security.js实现的RSA加密功能示例

    下面是“security.js实现的RSA加密功能示例”的完整攻略。 1. 安装security.js 首先需要安装security.js,它是一个纯JavaScript库,可以在浏览器和Node.js环境下使用。 在浏览器环境下,可以通过script标签引入: <script src="https://cdn.bootcdn.net/aja…

    PHP 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部