Home >Backend Development >PHP Tutorial >Quick sort PHP implementation php quick sort method php quick sort ideas quick sort algorithm

Quick sort PHP implementation php quick sort method php quick sort ideas quick sort algorithm

WBOY
WBOYOriginal
2016-07-29 08:54:561403browse

<code><span>/**
 *
 * 快速排序:不稳定,时间复杂度 最理想 O(nlogn) 最差时间O(n^2)
 * 快速排序是对冒泡排序的一种本质改进。它的基本思想是通过一趟扫描后,
 * 使得排序序列的长度能大幅度地减少。在冒泡排序中,一次扫描只能确保最大数值的数移到正确位置,
 * 而待排序序列的长度可能只减少1。快速排序通过一趟扫描,就能确保某个数(以它为基准点吧)的左边各数都比它小,
 * 右边各数都比它大。然后又用同样的方法处理它左右两边的数,直到基准点的左右只有一个元素为止。
 *<span> @param</span> array $arr
 *<span> @return</span> array
 */</span><span><span>function</span><span>fastSort</span><span>(array <span>$arr</span>)</span>{</span><span>if</span>(count(<span>$arr</span>) > <span>1</span>){
        <span>$num</span> = <span>$arr</span>[<span>0</span>];
        <span>$arrSmall</span> = [];
        <span>$arrBig</span> = [];
        <span>foreach</span> (<span>$arr</span><span>as</span><span>$item</span>){
            <span>if</span>(<span>$item</span>><span>$num</span>){
                <span>$arrBig</span>[] = <span>$item</span>;
            }<span>elseif</span>(<span>$item</span><<span>$num</span>){
                <span>$arrSmall</span>[] = <span>$item</span>;
            }
        }
        <span>$arrSmall</span> = fastSort(<span>$arrSmall</span>);
        <span>$arrBig</span> = fastSort(<span>$arrBig</span>);
        <span>$arr</span> = array_merge(<span>$arrSmall</span>,[<span>$num</span>],<span>$arrBig</span>);
    }<span>else</span>{
        <span>return</span><span>$arr</span>;
    }
    <span>return</span><span>$arr</span>;
}</code>
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

The above introduces the PHP implementation of quick sorting, including quick sorting and PHP content. I hope it will be helpful to friends who are interested in PHP tutorials.

Statement:
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