Today, I have a feeling of wu Jun’s “Letter from Silicon Valley” : it is very important to finish the last 1%. In situ heap sort algorithm and implementation (PHP)
explain
Last blog algorithm and data structure of pile and heap sort heap sort two heap sort of ancillary space all need to create a O (n) (constructor is used in the new distribution of auxiliary space), the program at the time of opening auxiliary space and release the space will also consume a certain amount of time, if can most groups in situ heap sort, it saves open up and release the space of time, Time performance is better.
Train of thought
Given an array of size n, make the array heapify to the maximum heap, in which case the first element of the array is the maximum. After swapping the value with the last element of the array, make the first n-1 element heapify to the maximum heap, and swap the first element with the penultimate element of the array… And so on, the resulting array is sorted from smallest to largest.
- Note *
The heapsort heap implementation in the previous blog starts at 1, so the parent of the current element (subscript I) is I /2, the left child is 2i, and the right child is 2i+1; The subscript of the array is 0, so the parent of the current element (subscript I) is (i-1)/2, the left child is 2i+1, and the right child is 2i+2.
implementation
require('.. /SortingAdvance/QuickSort.php');
/** * heap sort */
function shiftDown(&$arr, $n, $i){
// the last non-leaf node of heapify is $n-1
while( 2*$i + 1 < $n ){
/ / the left node
$j = 2*$i + 1;
// Check whether the right node exists and the right node is larger than the left node
if( $j+1 < $n && $arr[$j+1] > $arr[$j] ) $j ++;
if( $arr[$i] >= $arr[$j] ) break;
// swap( $arr[$i] , $arr[$j] );
swap( $arr, $i , $j );
$i = $j;
// print_r($arr);}}function selfHeadSort(&$arr, $n){
// The leaf node is already heapify, so start with the (n-1)/2 non-leaf node
for ($i=(int)(($n- 1) /2); $i >=0 ; $i--) {
shiftDown($arr, $n, $i);
}
$arr = $arr; $arr = $arr
// Start with the last element, swap with the first, and then heapify the first element
for ($i=$n- 1; $i > 0 ; $i--) {
swap( $arr, 0 , $i);
shiftDown($arr, $i, 0);
}
}
$n = 10000;
$arr = generateRandomArray($n, 0, $n);
$copy_arr1 = $arr;
$copy_arr2 = $arr;
$copy_arr3 = $arr;
$copy_arr4 = $arr;
testSort("selfHeadSort"."selfHeadSort", $arr, $n);
testSort("mergeSort"."mergeSort", $copy_arr1, $n);
testSort("quickSort"."quickSort", $copy_arr2, $n);
testSort("quickSort2"."quickSort2", $copy_arr3, $n);
testSort("quickSort3"."quickSort3", $copy_arr4, $n);
? >
Copy the code
Loss of time
The selfHeadSort running time is 0.062602043151855s mergeSort running time is 0.670814037323s quickSort running time is: 0.033109188079834s quickSort2 running time: 0.021806955337524s quickSort3 running time: 0.054163932800293sCopy the code
— — — — — — — — — — — — — — — — — — — — — — — — — gorgeous line — — — — — — — — — — — — — — — — — — — —
After watching the friends can click a like/follow, your support is the biggest encouragement to me.
Personal blog tomato technology small stack and gold digging home page
If you want to know more, please follow my wechat official account: Tomato Technology Xiaozhan