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-08-31

归并排序

// 归并排序 // 思路: // 复杂度:时间 O(nlgn) | 空间 O(n)

function sortMerge(arr) {
    const len = arr.length;
    if(len < 2) {
        return arr;
    }
    let mid = Math.floor(len/2);
    let left = arr.slice(0,mid);
    let right = arr.slice(mid);
    return merge(sortMerge(left),sortMerge(right));
}

function merge(left,right) {
    let arr=[];
    console.log(left,right)
    while(left.length && right.length) {
        if(left[0] < right[0]) {
            arr.push(left.shift())
        }else {
            arr.push(right.shift())
        }
    }
    while(left.length) {
        arr.push(left.shift())
    }
    while(right.length) {
        arr.push(right.shift())
    }
    return arr;
}

// let arr = [1,34,5,56,6,78,0,3]
let arr = [3,1,2,4]
console.log(sortMerge(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
编辑 (opens new window)
上次更新: 2022/09/18, 15:06:58
1
快速排列

← 1 快速排列→

最近更新
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
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式