Detailed explanation of PHP heap sort algorithm
This article mainly introduces the heap sorting algorithm implemented in PHP, and analyzes the principles, implementation steps and related operating techniques of PHP heap sorting in the form of examples. Friends in need can refer to it
The details are as follows:
Heap is the collective name for a special type of data structure in computer science, usually an array object that can be viewed as a tree.
Heap{k1,k2,ki,…,kn} (ki <= k2i,ki <= k2i 1)|(ki >= k2i,ki >= k2i 1), (i = 1,2,3,4...n/2)
About the heap:
The value of a node in the heap is always not greater than Or not less than the value of its parent node;
The heap is always a complete binary tree (below).
The heap with the largest root node is called the maximum heap or large root heap, and the heap with the smallest root node is called the minimum heap or small root heap.
Complete Binary Tree
#When it comes to heap sorting, we have to mention complete binary trees. These basic concepts are everywhere on the Internet. I picked the simplest one. .
Complete binary tree: Except for the last level, the number of nodes on each level reaches the maximum; only a few nodes on the right side are missing on the last level.
My own conclusion is that it is precisely because of the following two characteristics,
1. Only the last layer is allowed to have vacant nodes and the vacancies are on the right, that is, the leaf nodes are only Can appear on the two largest levels (regularity of storage method);
2. If i>1, the parent of tree is tree[i p 2] (regularity of its parent and child node values);
makes sorting very convenient.
Heap sort
Heap sort uses the big top heap for ascending order, and the small top heap for descending order.
This example uses the small top heap in descending order to analyze.
Heap sorting steps are as follows:
1. We create an array $arr from the data (49, 38, 65, 97, 76, 13, 27, 50) ;
2. Use the array $arr to create a small top heap (the main steps will be explained in the code comments. The figure below is the process of using an array to create a small top heap);
3. Change the root of the heap ( The smallest element) is exchanged with the last leaf, and the heap length is reduced by one, and jumps to the second step;
4. Repeat steps 2-3 until there is only one node in the heap, and the sorting is completed.
PHP implementation of heap sort
//因为是数组,下标从0开始,所以,下标为n根结点的左子结点为2n+1,右子结点为2n+2; //初始化值,建立初始堆 $arr=array(49,38,65,97,76,13,27,50); $arrSize=count($arr); //将第一次排序抽出来,因为最后一次排序不需要再交换值了。 buildHeap($arr,$arrSize); for($i=$arrSize-1;$i>0;$i--){ swap($arr,$i,0); $arrSize--; buildHeap($arr,$arrSize); } //用数组建立最小堆 function buildHeap(&$arr,$arrSize){ //计算出最开始的下标$index,如图,为数字"97"所在位置,比较每一个子树的父结点和子结点,将最小值存入父结点中 //从$index处对一个树进行循环比较,形成最小堆 for($index=intval($arrSize/2)-1; $index>=0; $index--){ //如果有左节点,将其下标存进最小值$min if($index*2+1<$arrSize){ $min=$index*2+1; //如果有右子结点,比较左右结点的大小,如果右子结点更小,将其结点的下标记录进最小值$min if($index*2+2<$arrSize){ if($arr[$index*2+2]<$arr[$min]){ $min=$index*2+2; } } //将子结点中较小的和父结点比较,若子结点较小,与父结点交换位置,同时更新较小 if($arr[$min]<$arr[$index]){ swap($arr,$min,$index); } } } } //此函数用来交换下数组$arr中下标为$one和$another的数据 function swap(&$arr,$one,$another){ $tmp=$arr[$one]; $arr[$one]=$arr[$another]; $arr[$another]=$tmp; }
The following is the final result of sorting:
Related recommendations:
PHPHeap sort algorithmExample analysis
Instance analysis of Heap sort algorithm in Java
PHPHeap sort algorithmExample details
The above is the detailed content of Detailed explanation of PHP heap sort algorithm. 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

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

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

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.
