快速排序的JavaScript实现

快速排序是排序算法中使用最广泛,也是最快速的一种排序算法。
排序过程如下:
1、取数组中的某个元素作为基准数
2、遍历数组将小于基准数的放在基准数的左边,大于等于基准数的放在基准数的右边
3、对左右两边的序列分别进行上述操作
4、直到左右两边序列不再需要进行排序,即序列个数只剩一个

初始序列:{49 27 65 50 76 12 38}
第1趟:{49 27 12 38} 50 {65 76} //为了方便理解,取中间数为基准数
第2趟:{12} 27 {49 38} 50 65 {76} //针对左右序列分别进行上述操作
第3趟:12 27 {38} 49 50 65 76
第4趟:12 27 38 49 50 65 76

js代码实现

var quicksort = function(arr){
    var length = arr.length;
    if(arr.length < 2){
        return arr;
    }
    var leftArr = [];
    var rightArr = [];
    var pointIndex = parseInt(length/2);
    var point = arr[pointIndex];
    for(var i = 0;i < length;i++){
        if(i === pointIndex){
            continue;
        }
        if(arr[i] < point){
            leftArr.push(arr[i]);
        }else{
            rightArr.push(arr[i]);
        }
    }
    return quicksort(leftArr).concat(point,quicksort(rightArr));

};

快速排序最坏的情况时间复杂度为O(n2),最优的情况时间复杂度为O(nlogn),其平均时间复杂度为O(nlogn)

由于快速排序在排序过程中相同的元素会存在交换,比如序列[3,4,2,2,1,6],如果选择第二个数字2做为基准数,大于等于2的将会放在基准数后面,因此第一个数字2会往后放,存在相对位置变动。
因此快速排序是不稳定排序

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值