php 数组二分法查找函数代码

yizhihongxing

PHP中数组二分法查找函数代码:

function binary_search($arr, $key) {
    $low = 0;
    $high = count($arr) - 1;

    while ($low <= $high) {
        $mid = intval(($low + $high) / 2);

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

    return -1;
}

该代码实现了基本的二分法查找,通过输入数组和要查找的键来查找键的位置。

其中,$low为数组最小值的下标,$high为数组最大值的下标,$mid为中间值的下标。每一次循环,都将区间缩小一半,直到找到目标值或者缩小到区间为空。

示例1:

$arr = [1, 2, 3, 4, 5];
$key = 3;
$index = binary_search($arr, $key); // 2

if ($index !== -1) {
    echo "键为".$key."的元素下标为".$index;
} else {
    echo "键为".$key."的元素不存在";
}

数组 $arr 中包含了 1, 2, 3, 4, 5 五个数,要查找的键为3,则输出结果为“键为3的元素下标为2”。

示例2:

$arr = [1, 3, 5, 7, 9];
$key = 4;
$index = binary_search($arr, $key); // -1

if ($index !== -1) {
    echo "键为".$key."的元素下标为".$index;
} else {
    echo "键为".$key."的元素不存在";
}

数组 $arr 中包含了 1, 3, 5, 7, 9 五个数,要查找的键为4,则输出结果为“键为4的元素不存在”。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:php 数组二分法查找函数代码 - Python技术站

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

相关文章

  • 用php简单实现加减乘除计算器

    当用户在网站上需要进行加减乘除计算时,我们可以使用PHP语言来实现计算器的功能。下面是使用PHP实现计算器的完整攻略: 设计表单界面 首先,我们需要创建一个表单页面,其中包含输入框和运算符选项。例如,下面的代码: <!DOCTYPE html> <html> <head> <title>简单计算器</ti…

    PHP 2023年5月27日
    00
  • php下判断数组中是否存在相同的值array_unique

    首先, array_unique 函数可以用来去除数组中重复的值,返回一个新的数组。如果您想要判断一个数组中是否存在重复的值,您可以通过比较数组去重前后的长度来判断。 示例1:比较数组去重前后的长度来判断是否存在重复值 $array = array(‘a’, ‘b’, ‘c’, ‘d’, ‘c’, ‘e’, ‘a’); $count1 = count($ar…

    PHP 2023年5月26日
    00
  • php实现转换html格式为文本格式的方法

    下面是关于“php实现转换html格式为文本格式的方法”的完整攻略。 1. 目标 将HTML格式的字符串转换为纯文本格式的字符串,以便于在邮件等场景中使用。 2. 方法 2.1 使用strip_tags()函数 PHP提供了一个strip_tags()函数,可以将HTML标签从字符串中去除,从而获得纯文本格式的字符串。 实例1:将以下HTML字符串转换成纯文…

    PHP 2023年5月26日
    00
  • php pcntl_fork和pcntl_fork 的用法

    下面是关于”php pcntl_fork和pcntl_fork的用法”的完整讲解攻略。 1. 什么是pcntl_fork? pcntl_fork()是php提供的一个函数,它可以在一个进程内创建一个子进程。其语法如下: int pcntl_fork(); 调用该函数,会创建一个与原来进程几乎完全相同的进程,包括代码段、数据段、堆栈。在新进程中,fork()返…

    PHP 2023年5月27日
    00
  • PHP移动文件指针ftell()、fseek()、rewind()函数总结

    下面是对“PHP移动文件指针ftell()、fseek()、rewind()函数总结”的详细讲解。 1. ftell()函数的作用 ftell()函数用于获取当前文件指针的位置。它的用法非常简单,只需给函数传入文件指针即可,具体语法如下: int ftell(resource $handle); 其中,参数 $handle 表示文件指针,可以使用 fopen…

    PHP 2023年5月25日
    00
  • php str_getcsv把字符串解析为数组的实现方法

    PHP str_getcsv把字符串解析为数组的实现方法 在开发过程中,经常需要处理csv格式的数据,而php中可以通过str_getcsv函数来将csv格式的字符串解析成数组,本文将详细介绍str_getcsv函数的实现方法。 函数定义与参数 str_getcsv函数用于将csv格式的字符串转化为数组,其定义如下: array str_getcsv ( s…

    PHP 2023年5月26日
    00
  • php面试实现反射注入的详细方法

    让我来详细讲解一下用PHP实现反射注入的方法。 什么是反射注入? 反射注入,又称为“依赖注入”,是将一个对象实例注入到另一个对象中,以便后者可以使用前者提供的服务。反射注入可以显著减少代码的耦合度,提高代码的可维护性和可扩展性。 如何使用反射注入? 使用反射注入,需要先创建一个反射类,通过反射类获取到需要注入的类的构造函数,然后通过构造函数创建一个新的实例。…

    PHP 2023年5月27日
    00
  • 默默小谈PHP&MYSQL分页原理及实现

    介绍 PHP和MYSQL是当前非常流行的两个技术,而分页在Web开发中也是非常常用的功能。本文将详细介绍PHP和MYSQL分页原理及其实现,让开发者可以更好地理解和实现分页功能。 分页原理 分页主要涉及两个概念:当前页和每页显示的记录数。在进行分页时,需要计算出总记录数和总页数。 总记录数的计算非常简单,只需要查询数据表中总的记录数即可。 总页数的计算需要用…

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