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>' ;
?>
posted @ 2013-06-27 19:36  jlins  阅读(401)  评论(0编辑  收藏  举报