排序之冒泡排序

冒泡排序

1 动画

4208590040-5ac42b210af83.gif

2 思想

(1)对数组进行遍历,相邻两数两两比较,较大者放右边,这样子一趟遍历最大的数就到了数组最右边;

(2)继续以上操作,直至排序完毕。

3 解法

// 冒泡排序(已优化):如果本次没有元素交换,代表排序已完成
const bubbleSort = arr => {
    const length = arr.length
    if (length <= 1) return
    // 外层迭代排序的轮次,i < length -1 是因为只需要比较 length-1 次就排好了
    for (let i = 0; i < length - 1; i++) {
        let hasChange = false // 提前退出冒泡循环的标志位
        // 内层直接比较相邻两两的大小,迭代次数为未排序数-1(与后一个数进行比较)
        for (let j = 0; j < length - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                // 交换
                const temp = arr[j]
                arr[j] = arr[j + 1]
                arr[j + 1] = temp

                hasChange = true // 表示有元素交换
            }
        }

        // 没有交换则代表排序完成,提前退出冒泡循环
        if (!hasChange) break
    }
}

4 分析

时间复杂度
  • 最佳情况:O(n)

  • 最差情况:O(n²)

  • 平均情况:O(n²)

稳定性

稳定

参考资料

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值