算法导论 第七章快速排序与随机快速排序
2011-02-19 10:04
1061 查看
#include <iostream> #include <cstdlib> #include <time.h> using namespace std; void swap(int array[] , int i , int j) { if(i!=j) //This comparision is most important. { //Because function Partition always let its element exchang itself. //cout << array[i] << ' ' << array[j] << endl; array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j]; //cout << array[i] << ' ' << array[j] << endl; } } int Partition(int array[] , int begin , int end) { int sentinel = array[end]; int i = begin-1; for(int j=begin ; j<end ; j++) { if(array[j] <= sentinel) { i++; swap(array , i , j); } } swap(array , i+1 , end); return i+1; } void QuickSort(int array[] , int begin , int end) { int q; if(begin < end) { q = Partition(array , begin , end); QuickSort(array , begin , q-1); QuickSort(array , q+1 , end); } } int main() { const int n = 10; int a ; srand(time(0)); for(int i=1 ; i<n ; i++) { a[i] = rand()%100; } for(int i=1 ; i<n ; i++) { cout << a[i] << ' '; } cout << endl; QuickSort(a , 1 , n-1); for(int i=1 ; i<n ; i++) { cout << a[i] << ' '; } cout << endl; return 0; }
以上是算法导论上的快速排序的实现。
#include <iostream> #include <cstdlib> #include <time.h> using namespace std; void swap(int array[] , int i , int j) { if(i != j) //This comparision is most important. { //Because function Partition always let its element exchang itself. array[i] = array[i]+array[j]; array[j] = array[i]-array[j]; array[i] = array[i]-array[j]; } } int Partition(int array[] , int begin , int end) { int sentinel = array[end]; int i = begin-1; for(int j=begin ; j<end ; j++) { if(array[j] <= sentinel) { i++; swap(array , i , j); } } swap(array , i+1 , end); return i+1; } int RandomizedPartition(int array[] , int begin , int end) { srand(time(0)); int i = rand()%(end-begin+1)+begin; swap(array , i , end); return Partition(array , begin , end); } void QuickSort(int array[] , int begin , int end) { int q; if(begin < end) { q = RandomizedPartition(array , begin , end); QuickSort(array , begin , q-1); QuickSort(array , q+1 , end); } } int main() { const int n = 100; int a ; srand(time(0)); for(int i=1 ; i<n ; i++) { a[i] = rand()%100; } for(int i=1 ; i<n ; i++) { cout << a[i] << ' '; } cout << endl; QuickSort(a , 1 , n-1); for(int i=1 ; i<n ; i++) { cout << a[i] << ' '; } cout << endl; return 0; }
这段代码是随机快排。当数据基本有序,或数据大小相差悬殊时,采用这种算法。
以上两种算法都是递归执行的,如果系统栈有限,可以采取非递归实现的快排。
非递归实现的快排在另一篇博文里写过。
相关文章推荐
- 算法导论 第七章快速排序与随机快速排序
- 算法导论-第七章-快速排序:随机化快速排序C++实现
- 算法导论 第七章快速排序与随机快速排序
- 算法导论 第七章 随机快速排序
- 快速排序和随机快速排序
- 算法导论第七章快速排序的C++实现
- 普通快速排序与随机快速排序
- 算法导论-4.随机快速排序与线性时间排序
- 《github一天一道算法题》:快速排序和随机快速排序
- 《算法之美》---快速排序(随机快速排序)
- 算法导论 第七章:快速排序
- C/C++实现快速排序和随机快速排序
- 第七章快速排序之“快速排序的随机化版本RANDOM-QUICKSORT”
- 学习《算法导论》第七章 快速排序 总结
- 第七章快速排序之“采取“尾递归”和“三数取中”技术的快速排序”(思考题7-4、7-5)
- 算法导论笔记之----随机快速排序
- java实现快速排序和随机快速排序
- 算法导论 第七章快速排序与随机快速排序
- 算法导论-排序(二)快速排序、随机化快速排序
- 快速排序+随机快速排序