JS实现快排

快速排序的概念

快速排序(维基百科) https://zh.wikipedia.org/wiki/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F

白话算法 - 快速排序 http://blog.csdn.net/morewindows/article/details/6684558

递归方法实现

 1 function quickSort(arr, start, end) {
 2     if (start > end) {
 3         return;
 4     }
 5     let i = start,
 6         j = end,
 7         pivot = arr[start]; //存放基准数
 8     while (i !== j) {
 9         // 从右边开始,找第一个小于基准的位置
10         while (arr[j] >= pivot && i < j) {
11             j--;
12         }
13         // 从左边开始,找第一个大于基准的位置
14         while (arr[i] <= pivot && i < j) {
15             i++
16         }
17         // 交换两个数
18         if (i < j) {
19             let tmp = arr[i];
20             arr[i] = arr[j];
21             arr[j] = tmp;
22         }
23     }
24     // 最后把基准数归位
25     arr[start] = arr[i];
26     arr[i] = pivot;
27     // 递归处理左边
28     quickSort(arr, start, i - 1);
29     // 递归处理右边
30     quickSort(arr, i + 1, end);
31 }
32 var arr = [6, 1, 2, 7, 9, 3, 4, 5, 10, 8];
33 quickSort(arr, 0, arr.length - 1);
34 console.log(arr);

 

原文地址:https://www.cnblogs.com/caiyanhu/p/7054054.html