news 2026/3/28 0:42:26

经典算法题型之排序算法(四)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
经典算法题型之排序算法(四)

冒泡排序的第三种写法

第三种写法比较少见,它是在第二种写法的基础上进一步优化:

public static void bubbleSort(int[] arr) { boolean swapped = true; // 最后一个没有经过排序的元素的下标 int indexOfLastUnsortedElement = arr.length - 1; // 上次发生交换的位置 int swappedIndex = -1; while (swapped) { swapped = false; for (int i = 0; i < indexOfLastUnsortedElement; i++) { if (arr[i] > arr[i + 1]) { // 如果左边的数大于右边的数,则交换,保证右边的数字最大 int temp = arr[i]; arr[i] = arr[i + 1]; arr[i + 1] = temp; // 表示发生了交换 swapped = true; // 更新交换的位置 swappedIndex = i; } } // 最后一个没有经过排序的元素的下标就是最后一次发生交换的位置 indexOfLastUnsortedElement = swappedIndex; } }

经过再一次的优化,代码看起来就稍微有点复杂了。最外层的 while 循环每经过一轮,剩余数字中的最大值仍然是被移动到当前轮次的最后一位。

在下一轮比较时,只需比较到上一轮比较中,最后一次发生交换的位置即可。因为后面的所有元素都没有发生过交换,必然已经有序了。

当一轮比较中从头到尾都没有发生过交换,则表示整个列表已经有序,排序完成。

​测试:

public void test() { int[] arr = new int[]{6, 2, 1, 3, 5, 4}; bubbleSort(arr); // 输出: [1, 2, 3, 4, 5, 6] System.out.println(Arrays.toString(arr)); }

冒泡排序从 1956 年就有人开始研究,之后经历过多次优化。它的空间复杂度为 O(1),时间复杂度为 O(n^2),第二种、第三种冒泡排序由于经过优化,最好的情况下只需要 O(n) 的时间复杂度。

最好情况:在数组已经有序的情况下,只需遍历一次,由于没有发生交换,排序结束。

最差情况:数组顺序为逆序,每次比较都会发生交换。

但优化后的冒泡排序平均时间复杂度仍然是 O(n^2),所以这些优化对算法的性能并没有质的提升。正如 Donald E. Knuth(1974 年图灵奖获得者)所言:“冒泡排序法除了它迷人的名字和导致了某些有趣的理论问题这一事实外,似乎没有什么值得推荐的。”

​不管怎么说,冒泡排序法是所有排序算法的老祖宗,如同程序界经典的 “Hello, world” 一般经久不衰,总是出现在各类算法书刊的首个章节。但面试时如果你说你只会冒泡排序可就太掉价了,接下来我们就来认识一下他的继承者们。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 7:11:44

B站视频下载神器bilidown:一键保存高清视频的终极指南

B站视频下载神器bilidown&#xff1a;一键保存高清视频的终极指南 【免费下载链接】bilidown 哔哩哔哩视频解析下载工具&#xff0c;支持 8K 视频、Hi-Res 音频、杜比视界下载、批量解析&#xff0c;可扫码登录&#xff0c;常驻托盘。 项目地址: https://gitcode.com/gh_mirr…

作者头像 李华
网站建设 2026/3/27 5:07:51

Seeing Theory贝叶斯推断可视化教程:从零开始的交互式学习体验

Seeing Theory贝叶斯推断可视化教程&#xff1a;从零开始的交互式学习体验 【免费下载链接】Seeing-Theory A visual introduction to probability and statistics. 项目地址: https://gitcode.com/gh_mirrors/se/Seeing-Theory Seeing Theory是一个创新的概率与统计可视…

作者头像 李华
网站建设 2026/3/24 2:14:19

HoRain云--Python爬虫常见错误解决指南

&#x1f3ac; HoRain 云小助手&#xff1a;个人主页 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …

作者头像 李华
网站建设 2026/3/27 14:36:05

HoRain云--Linux静态路由配置终极指南

&#x1f3ac; HoRain 云小助手&#xff1a;个人主页 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …

作者头像 李华
网站建设 2026/3/27 5:58:43

Git commit规范:为TensorFlow项目建立清晰提交历史

Git commit规范&#xff1a;为TensorFlow项目建立清晰提交历史 在深度学习项目日益复杂的今天&#xff0c;一个看似微不足道的实践——如何写好一条 git commit 消息&#xff0c;往往决定了整个团队能否高效协作。尤其是在像 TensorFlow 这样的大型开源框架中&#xff0c;每天…

作者头像 李华
网站建设 2026/3/13 15:09:01

如何在TensorFlow-v2.9镜像中启用TensorBoard进行训练监控?

如何在TensorFlow-v2.9镜像中启用TensorBoard进行训练监控&#xff1f; 在深度学习项目的开发过程中&#xff0c;模型训练往往不是“一键完成”的黑箱流程。更常见的情况是&#xff1a;我们反复调整超参数、修改网络结构、更换优化器&#xff0c;却对模型内部发生了什么知之甚少…

作者头像 李华