zoukankan      html  css  js  c++  java
  • PHP实现快速排序算法

    快速排序(Quick Sort)是对冒泡排序的一种改进,属不稳定排序算法,由东尼·霍尔在1962年提出。快速排序基本步骤:从数列中挑出一个元素(一般称为称为“基准”),通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比基准小,另外一部分的所有数据都比基准大,与基准相等的数据可放在两部分中的任一部分,然后再按此方法递归地对这两部分数据分别进行处理,以达到整个数据变成有序序列。快速排序,最好情况下,时间复杂度为O(nlogn);最坏情况下,时间复杂度为O(n2);平均时间复杂度为O(nlogn)。

    快速排序示例图:

    PHP实现快速排序算法
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    <?php
    /**
      * 数据结构与算法(PHP实现) - 快速排序(Quick Sort)。
      *
      * @author 创想编程(TOPPHP.ORG)
      * @copyright Copyright (c) 2013 创想编程(TOPPHP.ORG) All Rights Reserved
      * @license http://www.opensource.org/licenses/mit-license.php MIT LICENSE
      * @version 1.0.0 - Build20130614
      */
    class QuickSort {
       /**
        * 需要排序的数据数组。
        *
        * @var array
        */
       private $data ;
     
       /**
        * 数据数组的长度。
        *
        * @var integer
        */
       private $size ;
     
       /**
        * 数据数组是否已排序。
        *
        * @var boolean
        */
       private $done ;
     
       /**
        * 构造方法 - 初始化数据。
        *
        * @param array $data 需要排序的数据数组。
        */
       public function __construct( array $data ) {
         $this ->data = $data ;
         $this ->size = count ( $this ->data);
         $this ->done = FALSE;
       }
     
       /**
        * 交换数据数组中两个元素的位置。
        *
        * @param integer $x 元素在数组中的索引。
        * @param integer $y 元素在数组中的索引。
        */
       private function swap( $x , $y ) {
         $temp = $this ->data[ $x ];
         $this ->data[ $x ] = $this ->data[ $y ];
         $this ->data[ $y ] = $temp ;
       }
     
       /**
        * 快速排序。
        *
        * @param integer $left 数组第一个元素索引。
        * @param integer $right 数组最后一个元素索引。
        */
       private function sort( $left , $right ) {
         if ( $left >= $right ) {
           return ;
         }
     
         $pivot = $this ->data[ $left ];
         $start = $left ;
         $end = $right ;
     
         while ( $start < $end ) {
           while ( $start < $end && $this ->data[ $end ] >= $pivot ) {
             -- $end ;
           }
     
           $this ->swap( $start , $end );
     
           while ( $start < $end && $this ->data[ $start ] < $pivot ) {
             ++ $start ;
           }
     
           $this ->swap( $start , $end );
         }
     
         $this ->sort( $left , $start - 1);
         $this ->sort( $start + 1, $right );
       }
     
       /**
        * 获取排序后的数据数组。
        *
        * @return array 返回排序后的数据数组。
        */
       public function getResult() {
         if ( $this ->done) {
           return $this ->data;
         }
     
         $this ->sort(0, $this ->size - 1);
         $this ->done = TRUE;
     
         return $this ->data;
       }
    }
    ?>
    示例代码
    1
    2
    3
    4
    <?php
    $quick = new QuickSort( array (5, 3, 8, 9, 6, 2));
    echo '<pre>' , print_r( $quick ->getResult(), TRUE), '</pre>' ;
    ?>
  • 相关阅读:
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    Evanyou Blog 彩带
    数论12——浅谈指数与对数
    数论11——大组合数
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3159645.html
Copyright © 2011-2022 走看看