排序算法系列之【快排算法】

  快速排序的基本思想是:通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序的目的。请看代码:

 1 #include<iostream>
 2 using namespace std;
 3 
 4 int Partion(int a[], int low, int high){
 5     int pivotkey;
 6     pivotkey = a[low];
 7     while (low < high){
 8         while (low < high&&pivotkey <= a[high])
 9             high--;
10         swap(a[low], a[high]);
11         while (low < high&& pivotkey >= a[low])
12             low++;
13         swap(a[low], a[high]);
14     }
15     return low;
16 }
17 
18 void QSort(int a[], int low, int high){
19     int pivot;
20     if (low < high){
21         pivot = Partion(a, low, high);
22         cout << endl;
23         QSort(a, low, pivot - 1);
24         QSort(a, pivot + 1, high);
25     }
26 }
27 
28 
29 void QuickSort(int a[], int n){
30     QSort(a, 0, n - 1);
31 }
32 
33 int main(){
34     int a[] = { 9, 5, 1, 6, 2, 3, 8, 4, 7,12,11,10 };
35     int n = 12;
36     QuickSort(a, n);
37     for (int i = 0; i < 12; i++){
38         cout << a[i] << " ";
39     }
40     cout << endl;
41     return 0;
42 }

上图是每进行一次递归后的序列。

posted @ 2017-05-10 01:05  我是畅游海  阅读(172)  评论(0编辑  收藏  举报