


Learn the principles and time complexity analysis of the heap sort algorithm in PHP
Heap sort is a sorting algorithm based on the heap data structure, and its time complexity is O(nlogn). This article will introduce the principles of the heap sort algorithm in the PHP language and provide code examples.
1. The definition and properties of a heap
Before learning heap sorting, you first need to understand the definition and properties of a heap. A heap is a complete binary tree in which the value of each node is greater than or equal to the value of its child nodes. We call such a heap a big-max heap. On the contrary, if the value of each node is less than or equal to the value of its child node, we call it a small top heap.
Due to the characteristics of the heap, the top element of the heap is the maximum or minimum value. Therefore, in heap sorting, we usually regard the array to be sorted as a complete binary tree and use the characteristics of the heap for sorting.
2. Principle of heap sort algorithm
The heap sort algorithm is mainly divided into two steps: building a heap and adjusting the heap.
- Build Heap: Adjust the array to be sorted into a large top heap.
The steps are as follows:
- Traverse forward one by one starting from the last non-leaf node (i.e. n/2-1), and call the function of adjusting the heap (adjustHeap).
- The function of adjusting the heap adopts a top-down approach to adjust the current node and its subtree to ensure that the current node is larger than its child nodes.
- Repeat the above two steps until the entire array is adjusted to a large top heap.
- AdjustHeap: Adjust the current node and its subtree into a large top heap.
The steps are as follows:
- Calculate the positions of its left and right child nodes based on the position of the current node.
- Compare the values of the current node and its left and right child nodes to find the position of the largest node.
- If the position of the maximum node is not the position of the current node, exchange the values of the maximum node and the current node, and call itself recursively to adjust the exchanged subtree.
- Sort (sortHeap): Exchange the top element of the heap (that is, the first element of the array) with the last leaf node, and then perform heap adjustments on the remaining n-1 elements.
The steps are as follows:
- Exchange the top element of the heap with the last leaf node.
- Reduce the scope of the heap, that is, ignore the last leaf node that has been sorted.
- Adjust the reduced range heap to maintain the nature of the large top heap.
- Repeat the above three steps until the range of the heap is reduced to 1.
3. PHP code example
The following is an example code for implementing the heap sort algorithm in PHP language:
function heapSort(&$arr) { $length = count($arr); // 构建大顶堆 for ($i = floor($length/2 - 1); $i >= 0; $i--) { adjustHeap($arr, $i, $length); } // 调整堆并排序 for ($i = $length - 1; $i >= 0; $i--) { // 交换堆顶元素和最后一个叶子节点 $temp = $arr[0]; $arr[0] = $arr[$i]; $arr[$i] = $temp; // 调整堆使其保持大顶堆性质 adjustHeap($arr, 0, $i); } } function adjustHeap(&$arr, $i, $length) { $largest = $i; // 最大值的位置 $left = $i * 2 + 1; // 左子节点的位置 $right = $i * 2 + 2; // 右子节点的位置 // 比较当前节点与左右子节点的值,找到最大值的位置 if ($left < $length && $arr[$left] > $arr[$largest]) { $largest = $left; } if ($right < $length && $arr[$right] > $arr[$largest]) { $largest = $right; } // 如果最大值的位置不是当前节点的位置,则交换两个位置的值,并递归调整堆 if ($largest != $i) { $temp = $arr[$i]; $arr[$i] = $arr[$largest]; $arr[$largest] = $temp; adjustHeap($arr, $largest, $length); } } // 测试 $arr = [8, 3, 6, 2, 9, 1]; heapSort($arr); print_r($arr); // 输出 [1, 2, 3, 6, 8, 9]
4. Time complexity analysis
The time complexity of heap sorting is O(nlogn). Among them, the time complexity of building the heap is O(n), and the time complexity of adjusting the heap is O(logn). Since n elements need to be sorted, the total time complexity is O(nlogn).
Summary
This article introduces the principles of the heap sort algorithm in the PHP language in detail and provides corresponding code examples. Heap sort is an efficient sorting algorithm suitable for large arrays to be sorted. By learning the heap sort algorithm, you can further improve your understanding and application capabilities of data structures and algorithms.
The above is the detailed content of Learn the principles and time complexity analysis of the heap sort algorithm in PHP.. For more information, please follow other related articles on the PHP Chinese website!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。


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

Dreamweaver Mac version
Visual web development tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.
