Array sorting and search algorithm in PHP
PHP is a very popular programming language that supports various data types and algorithms, of which array sorting and search algorithms are basic and important parts. This article will introduce commonly used array sorting and search algorithms in PHP, as well as their application scenarios and efficiency analysis.
1. Array sorting
PHP provides a variety of array sorting methods, including bubble sort, insertion sort, selection sort, quick sort, merge sort, etc. The following is an introduction and sample code for several commonly used algorithms:
- Bubble Sort
Bubble sort is a simple but inefficient The basic idea of the sorting algorithm is to start from the first element of the array and compare the sizes of adjacent elements in sequence. If the left element is larger than the right element, their positions are swapped. After this round of comparison, the largest element is moved to the end of the array. Then start from the first element and repeat the above operation, the time complexity is O(n^2).
Sample code:
function bubble_sort($arr) { $len = count($arr); for ($i = 0; $i < $len - 1; $i++) { for ($j = 0; $j < $len - $i - 1; $j++) { if ($arr[$j] > $arr[$j + 1]) { $temp = $arr[$j]; $arr[$j] = $arr[$j + 1]; $arr[$j + 1] = $temp; } } } return $arr; }
- Insertion Sort
Insertion sort is a relatively simple sorting algorithm. Its basic idea is to A data to be sorted is inserted into an already sorted sequence to achieve the purpose of sorting. Assuming that the previous elements have been sorted, start from the second element of the array and look forward to find a suitable position for the insertion operation. Similar to bubble sort, its time complexity is also O(n^2).
Sample code:
function insertion_sort($arr) { $len = count($arr); for ($i = 1; $i < $len; $i++) { $temp = $arr[$i]; for ($j = $i - 1; $j >= 0 && $arr[$j] > $temp; $j--) { $arr[$j + 1] = $arr[$j]; } $arr[$j + 1] = $temp; } return $arr; }
- Quick Sort
Quick sort is a commonly used efficient sorting algorithm. Its basic idea is to select Any element in the array is used as the base value, and then the remaining elements are divided into two subsequences: the numbers on the left are all smaller than the base value, and the numbers on the right are all greater than the base value. Then repeat the above steps for the left and right subsequences until the length of the subsequence is 1 or 0. The time complexity of quick sort is O(n log2 n), and it is unstable sort.
Sample code:
function quick_sort($arr) { $len = count($arr); if ($len <= 1) { return $arr; } $pivot_key = $arr[0]; $left_arr = array(); $right_arr = array(); for ($i = 1; $i < $len; $i++) { if ($arr[$i] <= $pivot_key) { $left_arr[] = $arr[$i]; } else { $right_arr[] = $arr[$i]; } } $left_arr = quick_sort($left_arr); $right_arr = quick_sort($right_arr); return array_merge($left_arr, array($pivot_key), $right_arr); }
2. Array search
The array search algorithms in PHP mainly include linear search, binary search and hash search. The following is an introduction and sample code for several commonly used algorithms:
- Linear Search
Linear search is a simple search algorithm. The basic idea is to start from the first element of the array and compare the values and keywords of the elements one by one to see if they are the same. If they exist, return the subscript of the element, otherwise -1 will be returned. The time complexity of linear search is O(n).
Sample code:
function linear_search($arr, $key) { $len = count($arr); for ($i = 0; $i < $len; $i++) { if ($arr[$i] == $key) { return $i; } } return -1; }
- Binary Search
Binary search is also called half search. The basic idea is to divide the ordered array into The two parts compare the size of the middle element and the keyword each time. If they are equal, the subscript of the element is returned. Otherwise, the search range is reduced by half according to the size relationship until the target element is found. The time complexity of binary search is O(log2 n).
Sample code:
function binary_search($arr, $key) { $low = 0; $high = count($arr) - 1; while ($low <= $high) { $mid = floor(($low + $high) / 2); if ($arr[$mid] == $key) { return $mid; } elseif ($arr[$mid] > $key) { $high = $mid - 1; } else { $low = $mid + 1; } } return -1; }
- Hash Search
Hash search is an efficient search algorithm that uses hash tables. The basic idea is to map the key of each element into a hash table, calculate its location through a hash function, and then find the required element in that location. The time complexity of hash search is O(1), but a hash table needs to be constructed and maintained.
The above is an introduction and sample code for array sorting and search algorithms commonly used in PHP. Choosing different algorithms according to actual application scenarios and data size can improve the efficiency of the code.
The above is the detailed content of Array sorting and search algorithm in PHP. 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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

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 PHP programming, algorithms are an integral part. Mastering common algorithms can not only improve code efficiency, but also help with subsequent program design. The following are common algorithms in PHP programming: Sorting algorithm Sorting algorithm refers to arranging a set of data into an ordered sequence according to certain rules. In PHP programming, commonly used sorting algorithms include bubble sort, insertion sort, selection sort, quick sort, etc. Among them, quick sort is the sorting algorithm with the lowest time complexity and is suitable for processing large-scale data. search algorithm search algorithm

PHP is a very popular programming language that supports various data types and algorithms, of which array sorting and search algorithms are basic and important parts. This article will introduce commonly used array sorting and search algorithms in PHP, as well as their application scenarios and efficiency analysis. 1. Array sorting PHP provides a variety of array sorting methods, including bubble sort, insertion sort, selection sort, quick sort, merge sort, etc. The following is an introduction and sample code for several commonly used algorithms: Bubble Sort (BubbleSort)

How to use PHP arrays for data sorting and filtering Introduction: When developing PHP applications, you often need to sort and filter arrays. For large amounts of data processing, sorting and filtering are very important operations. PHP provides a series of functions and methods that can easily sort and filter arrays. This article will introduce how to use PHP arrays to sort and filter data, and provide corresponding code examples. 1. Data sorting PHP provides a variety of array sorting methods. Commonly used methods include sort() and rsor.

PHP is a scripting language widely used in web development and is getting better and better at building dynamic websites. In Web development, data structures and algorithms are no less important than other programming categories, and their impact on program running efficiency is particularly significant. Especially in scenarios involving large amounts of data storage and processing, or high program performance requirements, data structures and algorithms have become a part that cannot be ignored. This article mainly introduces some commonly used data structures and algorithms in PHP. 1. Data structure array PHP array is a very common

With the popularity of the Internet and the continuous expansion of applications, the development of programming languages has become increasingly important. As a very popular programming language, PHP is also constantly developing. In the process of programming with PHP, PHP developers may face the need to represent some knowledge and automatically generate algorithms. So, how to represent knowledge and automatically generate algorithms in PHP? This article will discuss this below. 1. Knowledge representation Knowledge representation is a very important issue in the field of artificial intelligence. Know

PHP algorithm analysis: How to use binary search algorithm to quickly locate elements in an ordered array? Overview: The binary search algorithm is an efficient search algorithm that is suitable for finding specific elements in an ordered array. This article will introduce the principle of binary search algorithm in detail and give PHP code examples. Principle: The binary search algorithm quickly locates the target element by repeatedly reducing the search range by half. The process is as follows: first, narrow the search range to the beginning and end of the array; then, calculate the index of the middle element and compare it with the target element;

In-depth understanding of the core algorithms of PHP and Vue in the brain mapping function Introduction: In the modern Internet era, we often use a variety of applications to help us organize and manage information. Brain mapping is a common and practical way of organizing information, which can graphically display complex thinking processes. In this article, we will focus on the core algorithms of PHP and Vue in the brain mapping function and give code examples. 1. Characteristics of mind maps. Mind maps are a type of brain map that takes a central theme as its core and displays information related to that theme through a tree structure.

PHP algorithm analysis: How to use dynamic programming algorithm to solve the 0-1 knapsack problem? Introduction: Dynamic programming is an algorithmic idea commonly used to solve optimization problems. In program development, the 0-1 knapsack problem is a classic dynamic programming application scenario. This article will introduce how to use PHP to write a dynamic programming algorithm to solve the 0-1 knapsack problem, and provide specific code examples. What is the 0-1 knapsack problem? The 0-1 knapsack problem is a classic combinatorial optimization problem. The problem is set as follows: There is a backpack with a capacity of C. There are n objects
