十大经典排序算法-冒泡排序算法详解
十大经典排序算法
- 十大经典排序算法-冒泡排序算法详解
- 十大经典排序算法-选择排序算法详解
- 十大经典排序算法-插入排序算法详解
- 十大经典排序算法-希尔排序算法详解
- 十大经典排序算法-快速排序算法详解
- 十大经典排序算法-归并排序算法详解
- 十大经典排序算法-堆排序算法详解
- 十大经典排序算法-计数排序算法详解
- 十大经典排序算法-桶排序算法详解
- 十大经典排序算法-基数排序算法详解
一、什么是冒泡排序
1.概念
冒泡排序(Bubble Sort)是排序算法里面比较简单的一个排序。它重复地走访要排序的数列,一次比较两个数据元素,如果顺序不对则进行交换,并一直重复这样的走访操作,直到没有要交换的数据元素为止。
2.算法原理
这是一个无序数列:1、5、4、2、6、3,我们要将它按从小到大排序。按照冒泡排序的思想,我们要把相邻的元素两两比较,根据大小来交换元素的位置
首先开始第一轮比较
第一步:比较1和5,1比5小,顺序正确,元素位置不变
第二步:比较5和4,5比4大,顺序错误,交换元素位置
第三步:比较5和2,5比2大,顺序错误,交换元素位置
经过一轮比较后,6作为最大的元素到了序列的最右侧
接下来进行第二轮比较,从1和4开始比较,到最右边的3结束,6已经是有序的,不需要再参与比较
第二轮结束后,如下所示
第三轮结束后,如下所示
第四轮结束后,如下所示
第五轮结束后,如下所示
至此所有的元素都是有序的
3.算法实现
function sort(arr) {let length = arr.length;for (let i = 0; i < length - 1; i++) {for (let j = 0; j < length - i - 1; j++) {if (arr[j] > arr[j + 1]) {[arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];}}}
}let arr = [1, 5, 4, 2, 6, 3];
sort(arr);
console.log(arr);
二、算法优化
优化一
从图中可以看到,在第三轮时,序列已经是有序了,但程序还是进行了第四、第五轮排序。可以在排序时做个标记,如果序列已经有序了,就不再进行后续的排序
优化后代码如下:
function sort(arr) {let length = arr.length;for (let i = 0; i < length - 1; i++) {// 优化,isSorted判断是否有序,已经有序,不需要再继续交换let isSorted = true;for (let j = 0; j < length - i - 1; j++) {if (arr[j] > arr[j + 1]) {[arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];isSorted = false;}}if (isSorted) {break;}}
}let arr = [1, 5, 4, 2, 6, 3];
sort(arr);
console.log(arr);
优化二
看如下序列
第一步,2和3比较,2比3小,顺序正确,元素位置不变
第二步,3和1比较,3比1大,顺序错误,交换元素位置
第三步,3和4比较,3比4小,顺序正确,元素位置不变
第四步,4和5比较,4比5小,顺序正确,元素位置不变
第五步,5和6比较,5比6小,顺序正确,元素位置不变
可以看到后4位元素已经是有序了,但还是进行了比较,并且在第二轮,第三轮还会对后面有序的元素进行比较。可以通过记录每轮交换后,最后一次交换的位置,进行优化
优化后代码如下所示:
function sort(arr) {let length = arr.length;// 优化2,记录无序数列的边界,每次比较只需要比到这里为止let lastExchangeIndex = 0;let sortBorder = length - 1;for (let i = 0; i < length - 1; i++) {// 优化1,isSorted判断是否有序,已经有序,不需要再继续交换let isSorted = true;for (let j = 0; j < sortBorder; j++) {if (arr[j] > arr[j + 1]) {[arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];isSorted = false;lastExchangeIndex = j;}}sortBorder = lastExchangeIndex;if (isSorted) {break;}}
}let arr = [2, 3, 1, 4, 5, 6];
sort(arr);
console.log(arr);
其实这还不是最优的,有一种排序算法叫鸡尾酒排序算法,能对冒泡排序算法做进一步优化达到最优的目的,详情可参考鸡尾酒排序算法。
三、冒泡排序算法特点
1.时间复杂度
冒泡排序算法的每一轮要遍历所有元素,轮转的次数和元素数量相当,所以时间复杂度是O(N^2)
经过优化后,最优的情况,序列已经是顺序的,那么只要进行一次循环,所以最优时间复杂度是O(N)
2.空间复杂度
冒泡排序算法排序过程中需要一个临时变量进行两两交换,所需要的额外空间为1,因此空间复杂度为O(1)
3.稳定性
冒泡排序算法在排序过程中,元素两两交换时,相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法
另外推荐一个开发者小工具网站,个人觉得里面的Json格式化功能很强大,报错很详细
https://tinyutil.cn/
还可以输入表达式进行内容选取,对于复杂json非常多层级的内容展现非常用用处
十大经典排序算法-冒泡排序算法详解相关推荐
- 十大经典排序之冒泡排序
冒泡思想 冒泡排序是一种较为简单的排序算法,在数组中依次比较俩个相邻的元素,最后的排序结果是升序还是降序是由我们的代码来具体实现. 具体实现 我们想到的是用循环来遍历这个数组,来实现俩俩比较 //-1 ...
- 十大经典排序算法详解(一)冒泡排序,选择排序,插入排序
养成习惯,先赞后看!!! 你的点赞与关注真的对我非常有帮助.如果可以的话,动动手指,一键三连吧!!! 目录 1.算法的评判标准 2.排序算法的分类 3.十大经典排序算法-冒泡排序,选择排序,插入排序 ...
- 十大经典排序算法详解(三)-堆排序,计数排序,桶排序,基数排序
养成习惯,先赞后看!!! 你的点赞与关注真的对我非常有帮助.如果可以的话,动动手指,一键三连吧!!! 十大经典排序算法-堆排序,计数排序,桶排序,基数排序 前言 这是十大经典排序算法详解的最后一篇了. ...
- 十大经典排序算法-桶排序算法详解
十大经典排序算法 十大经典排序算法-冒泡排序算法详解 十大经典排序算法-选择排序算法详解 十大经典排序算法-插入排序算法详解 十大经典排序算法-希尔排序算法详解 十大经典排序算法-快速排序算法详解 十 ...
- 十大经典排序算法-快速排序算法详解
十大经典排序算法 十大经典排序算法-冒泡排序算法详解 十大经典排序算法-选择排序算法详解 十大经典排序算法-插入排序算法详解 十大经典排序算法-希尔排序算法详解 十大经典排序算法-快速排序算法详解 十 ...
- 十大经典排序算法-选择排序算法详解
十大经典排序算法 十大经典排序算法-冒泡排序算法详解 十大经典排序算法-选择排序算法详解 十大经典排序算法-插入排序算法详解 十大经典排序算法-希尔排序算法详解 十大经典排序算法-快速排序算法详解 十 ...
- 十大经典排序算法详解
本文转自 <卢明冬的博客> 文章目录 排序算法的分析和评价 2.十大排序经典算法总览 2.1 排序算法的分类 2.2 排序算法的性能 2.3 各阶复杂度性能对比 2.4 排序算法的初始状态 ...
- 十大经典排序算法-希尔排序算法详解
十大经典排序算法 十大经典排序算法-冒泡排序算法详解 十大经典排序算法-选择排序算法详解 十大经典排序算法-插入排序算法详解 十大经典排序算法-希尔排序算法详解 十大经典排序算法-快速排序算法详解 十 ...
- 十大经典排序算法-归并排序算法详解
十大经典排序算法 十大经典排序算法-冒泡排序算法详解 十大经典排序算法-选择排序算法详解 十大经典排序算法-插入排序算法详解 十大经典排序算法-希尔排序算法详解 十大经典排序算法-快速排序算法详解 十 ...
最新文章
- R语言基于模拟退火(Simulated Annealing)进行特征筛选(feature selection)
- dede织梦data目录正确迁移及引起的问题解决方法
- JAVA后端开发规范
- SCCM2012R2七:msi软件分发和卸载
- Apache Log4j2 远程代码执行 漏洞
- What Are You Talking About
- wxWidgets:wxDialog类用法
- python字符串equals方法_java中如何使用equals进行比较?
- python强制跳出while循环_python如何跳出while循环
- 手写哈希(实现简单的加数、查询)
- java程序员学习路线图 java程序员进阶路线
- html如何添加隶书字体,word如何添加隶书字体?
- 解决Gmail不能正常登录的问题,并推荐几个小窍门 [转]
- python中如何把xlsx、xls文件转换为txt文件?安排
- 使用KOG数据库进行注释
- html前端学习基础入门教程之HTML代码的优化 关键词密度
- java从邮箱获取邮件_javaMail正确读取邮箱内容的方式
- 第4章【思考与练习2】数据文件high-speed rail.csv存放着世界各国高速铁路的情况。对世界各国高铁的数据进行绘图分析。使用Basemap绘制地图及使用Pyecharts绘制地图。
- Chrome浏览器使用谷歌翻译插件的正确方法
- 欢聚时代YY/测试实习面试
热门文章
- 华为NAT(地址转换技术)
- php 安装 bzip2,Linux_Linux系统中安装使用Bzip2来压缩文件的方法讲解,安装 Bzip2命令如下:复制代码 - phpStudy...
- 假期无聊冰河开发了一款国民级游戏!
- labview传递簇数组到dll
- 计算机基础 华师网络作业答案,17春华师《网络技术基础》在线作业
- python 子进程和父进程参数传递
- RFID技术管理工具
- vim ~/.vimrc
- 如何看待互联网时代的网络金融安全?
- vs2017怎么安装python包 没有权限_VS2017无法进入安装界面问题的解决方法