


PHP finds whether an ordered array contains a certain value (binary search)
Question: For an ordered array, how to determine whether a given value exists in the array.
Idea: To determine whether it exists, the simplest way is to directly loop through the array and compare each value. But for ordered arrays, writing like this completely fails to take advantage of the "ordered" feature.
All we use "binary search",
//有序数组为 $arr = array(2,5,66,87,954,1452,5865); //查找值 $str = 1452; //我们先定义 三个参数 $front = 0;//一个开始值下标 $end = count($arr) - 1;//一个结束值下标 $mid = intval(($front + $end) / 2);//中间值下标
1. For the first comparison, we directly determine whether the search value str is equal to the intermediate value mid, and if it is equal, it returns true directly;
2. If the search value str is greater than the middle value mid, it means that the search value str may be to the right of the middle value, that is, the starting value front needs to be reassigned = the middle value mid 1, and the end value end does not need to be changed, and the middle value is sequentially mid is the new start value and end value;
3. If the search value str is less than the middle value mid, it means that the search value str may be to the left of the middle value, that is, the start value does not need to change, and the end value end needs to be reassigned. = middle value - 1, and the middle value mid is the start value and the new end value in turn;
-----As above, compare the incoming start value, end value, and middle value. Once the start value is greater than the end value, it means that it is not found and the query ends. Otherwise, it returns that it has been found.
The specific code is as follows:
$str = 89;//查找值 $arr = [1,55,66,89,420];//有序数组 $ren = find($arr, $str); echo '<pre class="brush:php;toolbar:false">'; var_dump($ren); function find($arr, $str){ $front = 0;//开始下标 $end = count($arr) - 1;//结束下标 while($front <= $end){//结束值 大于 开始值 ,反之则退出 $mid = intval(($front + $end) / 2);//中间值下标 if($str == $arr[$mid]){ return $mid;//存在直接返回值的下标 } if($str > $arr[$mid]){ $front = $mid + 1;//在前面 } if($str < $arr[$mid]){ $end = $mid - 1;//在后面 } } return false; }
Return result: 89 is the fourth element value subscript 3
Recommended video tutorial: "php tutorial"
The above is the detailed content of PHP finds whether an ordered array contains a certain value (binary search). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c
