目录

排序算法---快速排序

快速排序思想

  1. 从数组中选择一个元素作为基准点
  2. 排序数组,所有比基准值小的元素摆放在左边,而大于基准值的摆放在右边。每次分割结束以后基准值会插入到中间去。
  3. 最后利用递归,将摆放在左边的数组和右边的数组在进行一次上述的1和2操作。

快速排序代码实现

测试数组【6,5,4, 7,1】

第一轮: 第二轮: 第三轮:

对比值:6 对比值 5 对比值 4

左边 5,4,1 左边 4,1 左边 1

右边 7 右边 [] 右边 []

5,4,1,6,7 4,1,5,6,7 1,4,5,6,7

javascript 复制代码
function quickSort(arr) {
    if (arr.length <= 1) {
      return arr;
    }
    const left = []
    const right = []
    let temp = arr[0]
      for (let i = 1; i < arr.length; i++) {
        if (arr[i] > temp) {
          right.push(arr[i])
        } else {
          left.push(arr[i])
        }
      }
      return this.quickSort([...left]).concat(temp, this.quickSort(right))
}

快速排序复杂度

时间复杂度

快速排序的时间复杂度在平均情况下是O(nlogn),但在最坏情况下可能达到O(n^2)

空间复杂度

快速排序的空间复杂度依赖于递归调用的深度,理想情况下为O(logn),但在最坏情况下可能达到O(n)

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
uhakadotcom40 分钟前
JAX 框架:高性能数值计算的新时代
算法·面试·github
uhakadotcom1 小时前
构建实时API智能代理:快速构建多代理语音应用
算法·面试·github
uhakadotcom1 小时前
快速理解 tiktoken:OpenAI 的高效文本编码工具
算法·面试·github
做人求其滴1 小时前
蓝桥杯C/C++省赛/国赛注意事项及运行环境配置
算法·蓝桥杯·编译器·c/c++·算法竞赛·运行环境·第十六届
写个博客1 小时前
代码随想录算法训练营第十五天
算法
铃煦1 小时前
《算法笔记》3.3小节——入门模拟->图形输出
笔记·算法·图论
LuckyLay2 小时前
LeetCode算法题(Go语言实现)_39
算法·leetcode·golang
uhakadotcom2 小时前
NVIDIA Resiliency Extension(NVRx)简介:提高AI模型训练的容错能力
算法·面试
Tisfy2 小时前
LeetCode 2843.统计对称整数的数目:字符串数字转换
算法·leetcode·字符串·题解
Yyq130208696822 小时前
KTH5772 系列游戏手柄摇杆专用3D 霍尔位置传感器
算法·游戏·3d·小杨13020869682