Java排序算法总结(三):冒泡排序
创始人
2024-07-26 09:11:40
0

冒泡排序是计算机的一种排序方法,它的时间复杂度为O(n^2),虽然不及堆排序、快速排序的O(nlogn,底数为2),但是有两个优点:

1.“编程复杂度”很低,很容易写出代码;

2.具有稳定性,这里的稳定性是指原序列中相同元素的相对顺序仍然保持到排序后的序列,而堆排序、快速排序均不具有稳定性。

不过,一路、二路归并排序、不平衡二叉树排序的速度均比冒泡排序快,且具有稳定性,但速度不及堆排序、快速排序。冒泡排序是经过n-1趟子排序完成的,第i趟子排序从第1个数至第n-i个数,若第i个数比后一个数大(则升序,小则降序)则交换两数。

冒泡排序算法稳定,O(1)的额外的空间,比较和交换的时间复杂度都是O(n^2),自适应,对于已基本排序的算法,时间复杂度为O(n)。冒泡算法的许多性质和插入算法相似,但对于系统开销高一点点。

排序过程

设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R,凡扫描到违反本原则的轻气泡,就使其向上"漂浮",如此反复进行,直至***任何两个气泡都是轻者在上,重者在下为止。

代码实现:

  1. // 冒泡排序   
  2. public class BubbleSort {   
  3. public static void sort(Comparable[] data) {   
  4. // 数组长度   
  5. int len = data.length;   
  6. for (int i = 0; i < len - 1; i++) {   
  7. // 临时变量   
  8. Comparable temp = null;   
  9. // 交换标志,false表示未交换   
  10. boolean isExchanged = false;   
  11. for (int j = len - 1; j > i; j--) {   
  12. // 如果data[j]小于data[j - 1],交换   
  13. if (data[j].compareTo(data[j - 1]) < 0) {   
  14. temp = data[j];   
  15. data[j] = data[j - 1];   
  16. data[j - 1] = temp;   
  17. // 发生了交换,故将交换标志置为真   
  18. isExchanged = true;   
  19. }// end if   
  20. }// end for   
  21. // 本趟排序未发生交换,提前终止算法,提高效率   
  22. if (!isExchanged) {   
  23. return;   
  24. }// end if   
  25. }// end for   
  26. }// end sort   
  27. public static void main(String[] args) {   
  28. // 在JDK1.5版本以上,基本数据类型可以自动装箱   
  29. // int,double等基本类型的包装类已实现了Comparable接口   
  30. Comparable[] c = { 4, 9, 23, 1, 45, 27, 5, 2 };   
  31. sort(c);   
  32. for (Comparable data : c) {   
  33. System.out.println(data);   
  34. }   
  35. }   

使用冒泡排序法对n个数据进行排序,共需要进行n-1次的比较。如果本来就是有顺序的数据,也需要进行n-1次比较。冒泡排序法的算法很简单,效率也较差。

【编辑推荐】

  1. 解读PHP冒泡排序技巧
  2. 详解C#排序函数实现冒泡排序
  3. C++冒泡排序基本应用技巧分享
  4. VB.NET冒泡排序相关算法详解

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...