Home > Backend Development > PHP Tutorial > Sorting algorithm: PHP version quick sort, bubble sort_PHP tutorial

Sorting algorithm: PHP version quick sort, bubble sort_PHP tutorial

WBOY
Release: 2016-07-13 10:34:30
Original
914 people have browsed it

1. Quick sort

1. Introduction
Quick sort is a sorting algorithm developed by Tony Hall. On average, sorting n items requires O(n log n) comparisons. In the worst case, O(n2) comparisons are required, but this situation is uncommon. In fact, quicksort is often significantly faster than other Ο(n log n) algorithms because its inner loop can be implemented efficiently on most architectures.
Quick sort uses the divide and conquer strategy to divide a sequence (list) into two sub-series (sub-lists).
2. Steps
Pick an element from the sequence, called the "pivot",
Reorder the sequence, all elements smaller than the pivot value are placed in front of the pivot, and all elements smaller than the pivot value are placed in front of the pivot. The one with the larger value is placed behind the base (the same number can go to either side). After this partition exits, the base is in the middle of the sequence. This is called a partition operation.
Recursively sort the subarray of elements smaller than the base value and the subarray of elements greater than the base value.
3. Code implementation

Copy code The code is as follows:
function quickSort(array $array)
{
$len = count($array);
if($len <= 1)
{
return $array;
}
$key = $array[0];
$left = array();
$right = array();
for($i=1; $i<$len; ++$i)
{
if($array [$i] < $key)
{
$left[] = $array[$i];
}
else
$right[ ] = $array [$i];
}
}
$left = quickSort($left);
$right = quickSort($right);
return array_merge($left, array($key ), $right);
}

print '
';<p> print_r(quickSort(array(1,4,22,5,7,6,9)));<br> print '
';

4. Sorting effect
The process of sorting a column of numbers using quick sort

Sorting algorithm: PHP version quick sort, bubble sort_PHP tutorial

2. Bubble Sort
1. Introduction
Bubble Sort (Bubble Sort, translated in Taiwan as: bubble sort or bubble sort) is a simple sorting algorithm. It repeatedly walks through the sequence to be sorted, comparing two elements at a time and swapping them if they are in the wrong order. The work of visiting the array is repeated until no more exchanges are needed, which means that the array has been sorted. The name of this algorithm comes from the fact that smaller elements will slowly "float" to the top of the array through swapping.
2. Step
Compare adjacent elements. If the first one is bigger than the second one, swap them both.
Do the same for each pair of adjacent elements, starting with the first pair and ending with the last pair. At this point, the last element should be the largest number.
Repeat the above steps for all elements except the last one.
Continue repeating the above steps for fewer and fewer elements each time until there are no pairs of numbers to compare.
3. Code implementation

Copy code The code is as follows:
function bubbingSort(array $array)
{
for($i=0, $len=count($array)-1; $i<$len; ++ $i)
{
for($j=$len; $j>$i; --$j)
{
if($array[$j] < $array[$ j-1])
                                                                                                             $j- 1] = $temp;
}
}
}
return $array;
}

print '
';<br> print_r(bubbingSort(array(1,4,22,5,7,6,9))); print '
';


4. Sorting process

The process of sorting a column of numbers using bubble sort

Sorting algorithm: PHP version quick sort, bubble sort_PHP tutorial

http://www.bkjia.com/PHPjc/751510.html

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/751510.htmlTechArticle1. Quick sort 1. Introduction Quick sort is a sorting algorithm developed by Tony Hall. On average, sorting n items requires O(n log n) comparisons. In the worst case scenario...
source:php.cn
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template