数据结构和算法之冒泡排序

冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就交换位置,直到没有再需要交换的元素。该算法的名字由来是因为越小的元素会经由交换慢慢"浮"到数列的顶端。
否 是 是 否 开始冒泡排序 是否还有未排序的元素 排序完毕 从头开始比较相邻元素 是否需要交换元素位置 交换元素位置 继续比较下一组相邻元素 继续比较下一组相邻元素 排序结果

根据上述表格,我们可以得到详细的冒泡排序过程的描述。具体过程如下:

数据组 5 3 8 6 4
第一次排序 3 5 6 4 8
第二次排序 3 5 4 6 8
第三次排序 3 4 5 6 8
第四次排序 3 4 5 6 8

以下是使用JavaScript实现冒泡排序的示例代码:

javascript 复制代码
function bubbleSort(arr) {
   var len = arr.length; // 获取数组长度

   for (var i = 0; i < len - 1; i++) { // 外层循环控制比较轮数
     for (var j = 0; j < len - 1 - i; j++) { // 内层循环控制每轮比较次数
       // 比较相邻两个元素,如果顺序错误就交换它们
       if (arr[j] > arr[j + 1]) { // 如果当前元素大于下一个元素
         var temp = arr[j]; // 临时变量用于存储当前元素
         arr[j] = arr[j + 1]; // 将当前元素替换为下一个元素
         arr[j + 1] = temp; // 将下一个元素替换为临时变量
       }
     }
   }
   return arr; // 返回排序后的数组
}

// 使用示例
var arr = [5, 3, 8, 4, 2];
console.log(bubbleSort(arr));  // 输出 [2, 3, 4, 5, 8]

在上述代码中,bubbleSort函数接收一个数组 arr 并进行冒泡排序。内部的两层循环用于比较和交换元素的位置,外层循环控制总共需要比较的轮次。经过多轮的比较和交换,最终得到一个升序的排列。

相关推荐
强化学习与机器人控制仿真14 分钟前
字节最新开源模型 DA3(Depth Anything 3)使用教程(一)从任意视角恢复视觉空间
人工智能·深度学习·神经网络·opencv·算法·目标检测·计算机视觉
Lsx-codeShare14 分钟前
一文读懂 Uniapp 小程序登录流程
前端·javascript·小程序·uni-app
一 乐18 分钟前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot
Teacher.chenchong27 分钟前
R语言实现物种分布预测与生态位分析:多元算法实现物种气候生态位动态分析与分布预测,涵盖数据清洗、模型评价到论文写作全流程
开发语言·算法·r语言
mit6.82429 分钟前
高维状态机dp|环形dp
算法
Swift社区31 分钟前
LeetCode 427 - 建立四叉树
算法·leetcode·职场和发展
地狱恶犬萨煤耶38 分钟前
JavaScript-小游戏-2048
javascript
u***j32441 分钟前
算法设计模式总结
算法·设计模式
爱心发电丶1 小时前
基于UniappX开发电销APP,实现CRM后台控制APP自动拨号
javascript
地狱恶犬萨煤耶1 小时前
JavaScript-实现函数方法-改变this指向call apply bind
javascript