它的基本思想应该是将待排记录分成独立的两个部分,找出枢轴,实现枢轴左边的值都小于枢轴的值,枢轴右边都大于枢轴的值。这样子不断递归下去
function quicksort(arr,low,high){
var pivot;
if(low < high){
pivot = partition(arr,low,high);
quicksort(arr,low,pivot-1);
quicksort(arr,pivot+1,high);
}
return arr;
}
这个就是快排的入口函数,出现了partition方法。它的作用就是找出记录中的关键字,也就是枢轴
function partition(arr,low,high){
1. var pivot = arr[low];
2. while(low <= high){
3. while(low <= high && arr[high] >= pivot){
4. high--;
5. }
6. swap(arr,low,high);
7. while(low <= high && arr[low] < pivot){
8. low++;
9. }
10 swap(arr,low,high);
11 }
12 return low;
13 }
其实它的思想也是挺简单的,比如你有这样一系列数字:5 1 9 3 7 4 8 6 2。我们这里只计算第一趟快排,其他只是递归下去,思路是一致的。
最后有一个函数就是交换函数的
function swap(arr,low,high){
var temp;
temp = arr[low];
arr[low] = arr[high];
arr[high] = temp;
}
这个函数实现起来还是比较简单的
如果不太了解快排方法的人可以去看《大话数据结构》,写得浅显易懂。还有就是其实可以用闭包的方法封装partition和swap方法,就暴露出quicksort方法接口给外界就行了
原文:http://blog.csdn.net/monkindey/article/details/32312113