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

冒泡排序

// 冒泡排序 //时间复杂度(平均):O(n^2) //时间复杂度(最坏):O(n^2) //时间复杂度(最好):O(n) //空间复杂度():O(1) //稳定性:稳定

function bubbleSort(arr) {
    const len = arr.length;
    for(let i=0;i<len;i++){
        let flag = false;
        for(let j=0;j<len-1;j++){
            if(arr[j] > arr[j+1]) {
                [arr[j], arr[j+1]] = [arr[j+1],arr[j]];
                flag = true;
            }
        }
        if(flag == false) return arr;
    }
    return arr;
}

let arr = [6,5,3,2,22,56];
console.log(bubbleSort(arr))



function bubbleSort1(arr) {
    const len = arr.length;
    for(let i=0;i<len;i++){
        let flag = false;
        for(let j=0;j<len-1;j++){
            if(arr[j] > arr[j+1]) {
                [arr[j],arr[j+1]] = [arr[j+1],arr[j]];
                flag = true;
            }
            if(flag = false) return arr;
        }
    }
    return arr;
}

console.log(bubbleSort1(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
35
36
编辑 (opens new window)
上次更新: 2022/09/18, 15:06:58
快速排列
大数相加

← 快速排列 大数相加→

最近更新
01
DOM事件流 && DOM0 - DOM3 事件模型 && DOM事件流应用场景(冒泡、事件委托)
09-18
02
必备书单
09-11
03
url全过程
09-10
更多文章>
Theme by Vdoing | Copyright © 2022-2022 simonzhangs | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式