JavaScript 之冒泡排序

发布于 2023-05-13 14:30:40 字数 1335 浏览 51 评论 0

冒泡排序,是一个相对较为简单易于理解的排序算法。下面以升序为例。

原理

  • 比较相邻的两个元素a、b。若 a > b,则互换 a 与 b 的位置,否则不变。
  • 按照上面的规则,第一轮循环次数为 array.length - 1,一轮循环结束,数组最后一项应该是最大数。
  • 第二轮开始,循环次数为 array.length - 1 - 1,同样把本次循环的最大项互换到 array[length - 1 - 1] 的位置上。
  • 以此类推...

图示

冒泡排序

实现

// 冒泡排序(升序)
function bubbleSort(arr) {
  for (let i = 0; i < arr.length - 1; i++) {
    for (let j = 0; j < arr.length - i - 1; j++) {
      if (arr[j] > arr[j + 1]) {
        ;[arr[j], arr[j + 1]] = [arr[j + 1], arr[j]]
      }
    }
  }
  return arr
}

const array = [8, 12, 4, 0, 22, 8, 21, 3, 56]
console.log(bubbleSort(array)) // [0, 3, 4, 8, 8, 12, 21, 22, 56]

时间复杂度

可知冒泡排序执行次数是 (n-1) + (n-2) + ... + 2 + 1 = (n^2 - n)/2,根据 时间复杂度推导方式,可得到 O(n^2)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

尾戒

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

yili302

文章 0 评论 0

晚霞

文章 0 评论 0

LLFFCC

文章 0 评论 0

陌路黄昏

文章 0 评论 0

xiaohuihui

文章 0 评论 0

你与昨日

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文