JavaScript快速排序(quickSort)算法的实现方法总结

 更新时间:2023年11月21日 11:01:48   作者:进二开物  
快速排序的思想式 分治法,选一个基准点,然后根据大小进行分配,分配然完毕之后,对已经分配的进行递归操作,最终形成快速排序,所以递归也是快速排序思想的一个重要组成部分,本文主要给大家介绍了JavaScript实现快速排序的写法,需要的朋友可以参考下

什么是快速排序?

快速排序的思想式 分治法。选一个基准点,然后根据大小进行分配,分配然完毕之后,对已经分配的进行递归操作,最终形成快速排序。所以递归也是快速排序思想的一个重要组成部分。

基本思路

  • 基准点: 选中基准点,一般选择数组第一项,当然也可以随机或者指定数据。
  • 分区,一般分为 less/greater 或者 left/right
  • 递归: 对已有的分区经进行递归操作
  • 合并:将已有的数据进行合并

写法一:基础写法

function quickSort(arr) {
    // 数组小于 1 不用排序,直接返回即可
    if(arr.length <= 1) {
        return arr;
    }
    
    const p = arr[0]; // 选定数组第一个为基准点
    const left = []; // 左分区
    const right = []; // 右分区
    
    // 遍历给左右分区
    for(let i = 1; i < arr.length; i++) {
        if(arr[i] < p) {
            // 小于基准点放在左边
            left.push(arr[i])
        }else {
            // 大于基准点方在右边
            right.push(arr[i])
        }
    }
    // 合一并且对左右分区,递归处理
    
    return quickSort(left).concat(p, quickSort(right))
}

写法二: 函数式

function quickSort(arr) {
    if (arr.length <= 1) {
        return arr;
    } else {
        const p = arr[0]; // 确定中间值
        const left = arr.slice(1).filter(x => x <= p);
        const right = arr.slice(1).filter(x => x > p);
        return quickSort(left).concat(p, quickSort(right))
    }
}

使用 filter 过滤,偏向函数式编程,写的代码更加简洁。

写法三:随机基准值

function randomizeQuickSort(arr) {
    if (arr.length <= 1) {
        return arr;
    } else {
        const pi = Math.floor(Math.random() * arr.length); // 随机基准值索引
        const p = arr[pi];
        const left = arr.slice(0, pi).concat(arr.slice(pi + 1).filter(x => x <= p));
        const right = arr.slice(pi + 1).filter(x => x > p);
        return randomizeQuickSort(left).concat(p, randomizeQuickSort(right))
    }
}

随机获取基准值索引,根据随机索引获基准值,所有这两个已知的值,就可以制作一个随机索引快速排序了。

写法四:三分法

function threeWayQuickSort(arr) {
    if (arr.length <= 1) {
        return arr;
    } else {
        const p = arr[0];
        const left = arr.filter(x => x < p);
        const mid = arr.filter(x => x === p); // 获取所有的中间值,避免重复计算
        const right = arr.filter(x => x > p);
        return threeWayQuickSort(left).concat(mid, threeWayQuickSort(right))
    }
}

三路法,将二路基础上,将自己看成一个中间数组,因为与自己相等的可能有很多。这样就避免了在其他数组中,还有中间数据的重复比较, 一种快速排序的优化。

排序算法的使用场景

  • 大规模数据排序速度,比其他的算法要快

复杂度分析

  • 快速排序的平均时间复杂度是 O(n log n) 这种复杂度是比较理想的。O(n log n) 来源是 划分 O(n)递归 O(log n) 的组合。

更难展望

  • 双轴快速排序
  • 尾递归优化

小结

文本主要讲解常用算法中的快速排序的算法, 快速排序的思想很简单,就是分与合配合递归的思想。选定一个基准值,然后进行对比分离,递归这个操作,然后重新配合在一起。当然排序算法也是可以根据自己的需求进行优化的。

相关文章

  • js中关于一个分号的崩溃示例

    js中关于一个分号的崩溃示例

    下面的js代码不管if条件的结果是true还是false都会执行大括号的代码,结果发现if条件括号后面多写了分号,崩溃啊
    2013-11-11
  • Opacity.js

    Opacity.js

    Opacity.js...
    2007-01-01
  • 微信小程序开发常用功能汇总

    微信小程序开发常用功能汇总

    这篇文章主要介绍了微信小程序开发常用功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • 利用JavaScript实现一个日期范围选择器

    利用JavaScript实现一个日期范围选择器

    日期范围选择器是一个常见的Web应用功能,它允许用户选择一个日期范围,本文我们将使用JavaScript来实现这个功能,感兴趣的小伙伴可以了解下
    2024-01-01
  • webpack.DefinePlugin与cross-env区别详解

    webpack.DefinePlugin与cross-env区别详解

    这篇文章主要介绍了webpack.DefinePlugin与cross-env区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • 微信小程序中使用自定义字体的实现与体验优化

    微信小程序中使用自定义字体的实现与体验优化

    由于微信支持的字体非常有限,不能满足个性化的需求,因此在开发的过程中可能会需要使用自定义字体,下面这篇文章主要给大家介绍了关于微信小程序中使用自定义字体的实现与体验优化的相关资料,需要的朋友可以参考下
    2022-02-02
  • 原生js实现手风琴功能(支持横纵向调用)

    原生js实现手风琴功能(支持横纵向调用)

    本文主要介绍了原生js实现手风琴功能(支持横纵向调用)的示例代码。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • 关于JS中的箭头函数

    关于JS中的箭头函数

    这篇文章主要介绍了关于JS中的箭头函数,ES6中允许使用=>来定义函数。箭头函数相当于匿名函数,并简化了函数定义,箭头函数在语法上比普通函数简洁多。箭头函数就是采用箭头=>来定义函数,省去关键字function,需要的朋友可以参考下
    2023-05-05
  • javascript中数组的冒泡排序使用示例

    javascript中数组的冒泡排序使用示例

    数组的冒泡排序很实用,不过还是有些同学们不会,于是在本文为大家详细介绍下,感兴趣的朋友不要错过
    2013-12-12
  • JS常用倒计时代码实例总结

    JS常用倒计时代码实例总结

    这篇文章主要介绍了JS常用倒计时代码,结合实例形式总结分析了JS常用的倒计时功能实现方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2017-02-02

最新评论