songbensong songbensong
首页
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
HTML/CSS
JavaScript
计算机网络
操作系统
更多
  • 分类
  • 标签
GitHub (opens new window)

松本松

一直在路上
首页
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
HTML/CSS
JavaScript
计算机网络
操作系统
更多
  • 分类
  • 标签
GitHub (opens new window)
  • 排序算法

    • 1
    • 归并排序
    • 快速排列
    • 冒泡排序
  • 大数相加
  • vue响应式
  • JS算法题
  • 排序算法
simonzhangs
2022-09-01

快速排列

// 快速排列 // 思路:选择数组中的一个值作为基准,将数组中小于该值的数置于该数之前,大于该值的数置于该数之后,接着对该数前后的两个数组进行重复操作直至排序完成。 // 参考:https://www.cnblogs.com/et-008/p/16472607.html // 时间复杂度 最好O(nlg(n)) 最坏:O(n2) | 空间:O(nlgn)

function quickSort(arr) {
    let len = arr.length;
    let left = [],right=[];
    if(len < 2) return arr;
    for(let i=1;i<len;i++){
        if(arr[i] < arr[0]) {
            left.push(arr[i]);
        }else {
            right.push(arr[i]);
        }
    }
    return quickSort(left).concat([arr[0]],quickSort(right))
}

const arr = [9, 4, 3, 1, 6, 3, 8, 7];
console.log(quickSort(arr)) 




function quickSort1(arr) {
    const len = arr.length;
    if (len < 2) return arr;
    let left = [],right=[];
    for(let i=1;i<len;i++){
        if(arr[i] < arr[0]) {
            left.push(arr[i])
        }else {
            right.push(arr[i])
        }
    }
    return quickSort(left).concat([arr[0]],quickSort(right))
}
console.log(quickSort1(arr))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
编辑 (opens new window)
上次更新: 2022/09/18, 15:06:58
归并排序
冒泡排序

← 归并排序 冒泡排序→

最近更新
01
DOM事件流 && DOM0 - DOM3 事件模型 && DOM事件流应用场景(冒泡、事件委托)
09-18
02
必备书单
09-11
03
url全过程
09-10
更多文章>

Related Issues not found

Please contact @xugaoyi to initialize the comment

Theme by Vdoing | Copyright © 2022-2025 simonzhangs | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式