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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值