源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

JS排序之快速排序详解

  • 时间:2022-05-04 17:44 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:JS排序之快速排序详解
本文为大家分享了JS快速排序的具体代码,供大家参考,具体内容如下 说明 时间复杂度指的是一个算法执行所耗费的时间 空间复杂度指运行完一个程序所需内存的大小 稳定指,如果a=b,a在b的前面,排序后a仍然在b的前面 不稳定指,如果a=b,a在b的前面,排序后可能会交换位置 [b]--JS快速排序--[/b] [b]原理[/b] 从数组中选定一个基数,然后把数组中的每一项与此基数做比较,小的放入一个新数组,大的放入另外一个新数组。然后再采用这样的方法操作新数组。直到所有子集只剩下一个元素,排序完成。 时间复杂度,空间复杂度,稳定性 [list] [*]平均时间复杂度O(nlogn)[/*] [*]最好情况O(nlogn)[/*] [*]最差情况O(n*n)[/*] [*]空间复杂度O(logn)[/*] [*]稳定性:不稳定 [/*] [/list] 快速排序的写法
var examplearr=[8,94,15,88,55,76,21,39];
function fastsort(arr){
  if(arr.length<2){
    return arr;
  }
  var left=[];
  var right=[];
  var pivotIndex=Math.floor(arr.length/2);
  var pivot=arr.splice(pivotIndex,1)[0];
  for(i=0;i<arr.length;i++){
    if(arr[i]<pivot){
      left.push(arr[i]);
    }else{
      right.push(arr[i])
    }
  }
  return fastsort(left).concat([pivot],fastsort(right));
}
console.log(fastsort(examplearr));


[b]解析[/b] pivotIndex是将数组的长度除2向下取整得到的一个数值,数组的长度是不断减半的,所以最后它的值为0 pivot是利用splice方法从数组里获取一个基数 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部