当前位置:首页 > JavaScript

js冒泡实现

2026-03-14 04:12:59JavaScript

js冒泡实现

冒泡排序实现

冒泡排序是一种简单的排序算法,通过重复地遍历要排序的数列,比较相邻的元素并交换它们的位置,使得较大的元素逐渐“浮”到数列的末端。

js冒泡实现

基本实现步骤

  1. 外层循环控制遍历的轮数,每一轮会将当前未排序部分的最大元素移动到正确位置。
  2. 内层循环负责比较相邻元素,如果前一个元素比后一个元素大,则交换它们的位置。
  3. 每一轮遍历后,最大的元素会被移动到数组末尾,因此下一轮遍历可以减少一个元素的比较。
function bubbleSort(arr) {
  const n = arr.length;
  for (let i = 0; i < n - 1; i++) {
    for (let j = 0; j < n - i - 1; j++) {
      if (arr[j] > arr[j + 1]) {
        // 交换相邻元素
        [arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];
      }
    }
  }
  return arr;
}

优化版本

可以通过添加标志位来优化冒泡排序,当某一轮遍历中没有发生任何交换时,说明数组已经有序,可以提前终止排序。

function optimizedBubbleSort(arr) {
  const n = arr.length;
  let swapped;
  for (let i = 0; i < n - 1; i++) {
    swapped = false;
    for (let j = 0; j < n - i - 1; j++) {
      if (arr[j] > arr[j + 1]) {
        [arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];
        swapped = true;
      }
    }
    if (!swapped) break;
  }
  return arr;
}

时间复杂度分析

  • 最坏情况时间复杂度:O(n²),当数组是逆序时。
  • 最好情况时间复杂度:O(n),当数组已经有序时(优化版本)。
  • 平均时间复杂度:O(n²)。

冒泡排序是一种稳定的排序算法,适合小规模数据的排序。对于大规模数据,更高效的排序算法如快速排序或归并排序更为适用。

标签: js
分享给朋友:

相关文章

js实现分页

js实现分页

分页的基本实现思路 在JavaScript中实现分页功能通常需要结合前端和后端逻辑。前端负责渲染分页控件和处理用户交互,后端负责提供分页数据。 前端分页实现 纯前端分页适用于数据量较小的情况,可以直…

js 实现倒计时

js 实现倒计时

实现倒计时的基本方法 使用 JavaScript 实现倒计时可以通过 setInterval 或 setTimeout 结合日期计算来完成。以下是两种常见实现方式。 使用 setInterval 实…

js实现tab选项卡切换

js实现tab选项卡切换

实现Tab选项卡切换的JavaScript方法 使用纯JavaScript实现Tab切换功能,可以通过监听点击事件动态切换内容显示状态。以下是两种常见实现方式: 基础DOM操作实现 /…

js实现投球

js实现投球

实现投球动画的基本思路 使用JavaScript和CSS动画结合的方式模拟投球效果。核心是通过改变元素的位置、旋转和缩放属性,配合定时器或CSS过渡实现平滑动画。 创建基础HTML结构 <…

链表实现js

链表实现js

链表的基本概念 链表是一种线性数据结构,由一系列节点组成,每个节点包含数据和一个指向下一个节点的指针(单向链表)或两个指针(双向链表)。与数组不同,链表在内存中非连续存储,插入和删除操作更高效,但随机…

js实现交换

js实现交换

交换变量的方法 在JavaScript中,交换两个变量的值有多种方法。以下是常见的几种实现方式: 使用临时变量 通过引入一个临时变量来存储其中一个变量的值,实现交换: let a = 1; le…