Home Backend Development PHP Tutorial Three ways to sort arrays in PHP_PHP Tutorial

Three ways to sort arrays in PHP_PHP Tutorial

Jul 13, 2016 pm 05:50 PM
php one bubble turn up arrangement sort number array method most of illustrate

1. Bubble sorting method
Description: Find the largest number, arrange it to the end, and then continue to find

Example:
$arr = array(3,5,-1,0,2);
for($i=0;$i for($j=0;$j If($arr[$j]>$arr[$j+1]){
               $temp = $arr[$j];
               $arr[$j]=$arr[$j+1];
               $arr[$j+1]=$temp;
}
}
}
Comprehension:
3, 5, -1, 0, 2
//Compare starting from the first number and going backwards. If it is larger than the following number, adjust the position with the following number
//The first time, 3 is less than 5, then it remains unchanged
//The second time, 5 is greater than -1, then it becomes
3, -1, 5, 0, 2
//The third time, 5 is greater than 0
3, -1, 0, 5, 2
//The fourth time, 5 is greater than 2
3, -1, 0, 2, 5
This completes an inner loop. At this time, the last number is sorted and will not participate next time
3, -1, 0, 2, 5 The second outer loop begins. The first time: 3 is greater than -1
-1, 3, 0, 2, 5
The second time: 3 is greater than 0
-1, 0, 3, 2, 5
The third time: 3 is greater than 2
-1, 0, 2, 3, 5
This completes the sorting of the next two digits, and so on
-1, 0, 2, 3, 5
2. Selection sorting method Description: First assume that the first number is the smallest number, and then compare the following numbers with it in turn. If the assumed number is not the smallest number, swap its position with the following smallest number
$arr=array(2,1,-1,3,0);
for($i=0;$i $minval = $arr[$i];
$minindex = $i;
for($j=1+$i;$j If($arr[$j]<$minval){
               $minval = $arr[$j];
               $minindex = $j;
}
}
$temp = $arr[$i];
$arr[$i] = $arr[$minindex];
$arr[$minindex] = $temp;
}
Comprehension:
2, 1, -1, 3, 0
//Assume that the first number 2 is the minimum value, and the subsequent numbers are compared with 2 in turn to find the smallest number
Process:
1 is less than 2, then minval=1
-1 is less than 1, then minval=-1
3 is greater than -1, unchanged
0 is greater than -1, unchanged
So now we have found the smallest number in the array, which is -1
Swap the positions of -1 and 2 to complete the sorting of the first number
So now the array becomes
-1, 1, 2, 3, 0
Now the first number -1 is already in order, so it will not participate in the comparison and continue to the next
Now assume minval=1
2 is greater than 1, unchanged
3 is greater than 1, unchanged
0 is less than 1, then minval=0
Now that one cycle is completed, swap the positions of 0 and 1 to complete the sorting of the second number
So now the array becomes
-1, 0, 2, 3, 1
//The following push method is the same as above. . .

3. Insertion sort method description: First assume that the first number in an array is a separate ordered array, and then compare the following number with it [as I grows here, it becomes them]. If If the following number is smaller than the assumed number, move the smaller number back, and finally move that number to the front
$arr=array(2,1,-1,3,0);
for($i=1;$i $insertval=$arr[$i];
$insertindex = $i-1;
While($insertindex>=0 && $insertval<$arr[$insertindex]){
          $arr[$insertindex+1]=$arr[$insertindex];
         $insertindex--;
}
$temp = $arr[$i];
$arr[$insertindex+1]=$insertval;
}
Comprehension:
2, 1, -1, 3, 0
//For the first time, save the number 1 to be inserted as insertval, and then compare insertval with 2. 1 is less than 2, so move 2 back to become the following picture
2, 2, -1, 3, 0
//At this time, there is no number in front of 2, insertindex=0, so the comparison is completed, then insert insertval to the found position. It becomes as shown below
1, 2, -1, 3, 0
//At this time, 1 and 2 become ordered arrays
//The second time, first save the number to be inserted -1 as insertval, and then compare insertval with 2. -1 is less than 2, so move 2 back to become the following picture
1, 2, 2, 3, 0
//At this time, compare insertval with 1. If -1 is less than 1, then move -1 back to become the following picture (this is a process of comparing the number to be inserted with the previous ordered array)
1, 1, 2, 3, 0
//At this point, insertindex has come to an end, so insert insertval at this position
-1, 1, 2, 3, 0
//The following method is as above



Excerpted from Bell’s Technology Blog

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/478255.htmlTechArticle1. Instructions for bubble sorting method: Find the largest number, arrange it to the end, and then continue to find examples: $ arr = array(3,5,-1,0,2); for($i=0;$icount($arr)-1;$i++){ for($j=0;$jcount($arr)- 1-$i...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Do I need to use flexbox in the center of the Bootstrap picture? Do I need to use flexbox in the center of the Bootstrap picture? Apr 07, 2025 am 09:06 AM

There are many ways to center Bootstrap pictures, and you don’t have to use Flexbox. If you only need to center horizontally, the text-center class is enough; if you need to center vertically or multiple elements, Flexbox or Grid is more suitable. Flexbox is less compatible and may increase complexity, while Grid is more powerful and has a higher learning cost. When choosing a method, you should weigh the pros and cons and choose the most suitable method according to your needs and preferences.

What is Cross-Site Request Forgery (CSRF) and how do you implement CSRF protection in PHP? What is Cross-Site Request Forgery (CSRF) and how do you implement CSRF protection in PHP? Apr 07, 2025 am 12:02 AM

In PHP, you can effectively prevent CSRF attacks by using unpredictable tokens. Specific methods include: 1. Generate and embed CSRF tokens in the form; 2. Verify the validity of the token when processing the request.

PHP and Python: Comparing Two Popular Programming Languages PHP and Python: Comparing Two Popular Programming Languages Apr 14, 2025 am 12:13 AM

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.

Explain the match expression (PHP 8 ) and how it differs from switch. Explain the match expression (PHP 8 ) and how it differs from switch. Apr 06, 2025 am 12:03 AM

In PHP8, match expressions are a new control structure that returns different results based on the value of the expression. 1) It is similar to a switch statement, but returns a value instead of an execution statement block. 2) The match expression is strictly compared (===), which improves security. 3) It avoids possible break omissions in switch statements and enhances the simplicity and readability of the code.

PHP: A Key Language for Web Development PHP: A Key Language for Web Development Apr 13, 2025 am 12:08 AM

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

The Future of PHP: Adaptations and Innovations The Future of PHP: Adaptations and Innovations Apr 11, 2025 am 12:01 AM

The future of PHP will be achieved by adapting to new technology trends and introducing innovative features: 1) Adapting to cloud computing, containerization and microservice architectures, supporting Docker and Kubernetes; 2) introducing JIT compilers and enumeration types to improve performance and data processing efficiency; 3) Continuously optimize performance and promote best practices.

PHP vs. Python: Understanding the Differences PHP vs. Python: Understanding the Differences Apr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

Describe the purpose and usage of the ... (splat) operator in PHP function arguments and array unpacking. Describe the purpose and usage of the ... (splat) operator in PHP function arguments and array unpacking. Apr 06, 2025 am 12:07 AM

The... (splat) operator in PHP is used to unpack function parameters and arrays, improving code simplicity and efficiency. 1) Function parameter unpacking: Pass the array element as a parameter to the function. 2) Array unpacking: Unpack an array into another array or as a function parameter.

See all articles