快速排序-php

 

使用php实现的快速排序:
 

<?php
//快速排序比希尔排序快一个数量级,虽然他们都是O(nlog2n),进过测试100万条随机记录,使用快速排序只需要5秒多

//快速排序相当于织布机的形式,从最右面和参照因子对比
function quickSort(&$arr, $low,$high)
{
    //第一个为参照值,小于此值的放在左面,>=此值的放在右面
    $temp = $arr[$low];
    $i = $low;
    $j = $high;
    //执行到最后一次递归,因为low>high所以递归就会终止
    if ($low < $high) {
        while($i < $j) {
            //从右面开始找,忽略比因子大的
            while($i < $j && $arr[$j] >= $temp) {
                $j --;
            }

            if ($i < $j) {
                $arr[$i++] = $arr[$j];
            }

            //以上的$arr[$i++] = $arr[$j]执行后接下来需要从左面开始找比因子值大的
            //忽略<=因子值的数据
            while ($i < $j && $arr[$i] <= $temp) {
                $i ++;
            }

            //把比因子值大的放到右面
            if ($i < $j) {
                $arr[$j --] = $arr[$i];
            }
        }

        $arr[$i] = $temp;

        // 后续的递归
        quickSort($arr, $low, $i-1);
        quickSort($arr, $i+1, $high);
    }
}

echo '<pre>';
$start_time = microtime(true);
$arr = range(1, 1000000);
shuffle($arr);

array_unshift($arr, 0);
//print_r($arr);

quickSort($arr, 1,count($arr)-1);

//print_r($arr);

$end_time = microtime(true);

echo $end_time -$start_time;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值