JS算法笔记—快速排序
//快速排序
function quickSort(arr){
function swap(arr,right,left){
var tmp = arr[right];
arr[right]=arr[left];
arr[left]=tmp;
}
function partition(arr,left,right){//分区操作,
var pivotValue=arr[right]//最右面设为标准
var storeIndex=left;
for(var i=left;i<right;i++){
if(arr[i]<=pivotValue){
swap(arr,storeIndex,i);
storeIndex++;
}
}
swap(arr,right,storeIndex);
return storeIndex//返回标杆元素的索引值
}
function sort(arr,left,right){
if(left>right) return;
var storeIndex=partition(arr,left,right);
sort(arr,left,storeIndex-1);
sort(arr,storeIndex+1,right);
}
sort(arr,0,arr.length-1);
return arr;
}
let arr = [1,5,3,6,8,4,6,88,55,99]
quickSort(arr);//[1, 3, 4, 5, 6, 6, 8, 55, 88, 99]
//原理就是以数组的第一个元素为基准元素,从第二个元素开始对基准元素进行比较,如果比基准元素小则让基准点前进
//一位,同时把现基准点上的值与对比元素的值对换。一次遍历下来后,现基准点所在的位置就是最后一个比基准元素小的
//元素所在的位置,右边是大于或者等于基准元素的元素,左边是小于基准元素的元素(除了第一位,第一位是基准元素)
//,所以最后一步操作就是让现基准点上的元素和第一位上的元素(基准元素)互换,确保基准点和基准元素对应上。之后
//递归调用就可以完成。