最简洁的快速排序

1).快速排序原理

  1. 取一个基准值(哨兵pivot)。
  2. 将基准值依次和其他项进行比较,小于基准值的放到一个集合A里,大于等于基准值的放到另一个集合B里。
  3. 再将A、B集合接着重复步骤1、2。

2).js程序设计

 function quickSort(arr){
     if(!arr || arr.length<2) return arr
     const pivot = arr.pop() //获取数组最后一位值作为基准值
     const left = arr.filter(item => item< pivot) // 小于基准值的集合A
     const right = arr.filter(item => item >= pivot) // 大于等于基准值的集合B
     return quickSort(left).concat([pivot],quickSort(right)) //集合A、基准值和集合拼接起来,A和B采用递归接着排序
 }

3).总结分析
优点:程序简单明了实现了快速排序,方便理解。
缺点:定义了三个变量pivot,left,right消耗了空间复杂度Q(3n)=Q(n),另外里面进行了两次filter数组迭代计算增加了
时间复杂度Q(2n)=Q(n), 每次将集合一分为二计算量也会减小很多,复杂度为logn,最坏情况下进行n-1次递归运算,所有平均时间复杂度为nlogn

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值