成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java排序算法總結(三):冒泡排序

開發 后端 算法
冒泡排序(BubbleSort)就是依次比較相鄰的兩個數,將小數放在前面,大數放在后面。下面讓我們一起來看冒泡排序在Java中的算法實現。

冒泡排序是計算機的一種排序方法,它的時間復雜度為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冒泡排序相關算法詳解

 

責任編輯:于鐵 來源: 百度
相關推薦

2022-11-21 07:58:10

Java排序冒泡排序

2011-04-20 13:56:08

選擇排序

2011-04-20 14:19:00

希爾排序

2011-04-20 15:06:44

堆排序

2011-04-20 15:20:03

快速排序

2011-04-20 12:49:44

插入排序

2011-04-20 14:29:07

歸并排序

2011-04-20 16:05:15

基數排序

2020-07-05 09:12:42

java冒泡排序算法

2023-03-06 08:10:52

數據結構算法數據

2019-09-17 16:30:18

java排序算法

2015-08-26 10:13:55

排序算法總結

2023-03-02 08:15:13

2019-10-30 08:53:46

JavaScript冒泡排序選擇排序

2018-11-21 10:47:46

排序算法TimsortPython

2021-01-21 05:22:36

排序算法選擇

2010-01-11 15:01:55

VB.NET冒泡排序

2015-09-01 10:21:53

排序算法總結

2009-09-10 16:30:11

C#排序函數

2023-05-05 06:43:13

算法冒泡排序元素
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久婷婷麻豆国产91天堂 | 国产玖玖 | 久久久精品日本 | 一级片网址 | 国产精品视频网 | 久久无毛 | 欧美1区| 三区四区在线观看 | 日韩一区二区三区视频在线播放 | 久久亚洲精品久久国产一区二区 | 在线国产一区二区三区 | 亚洲精久| 男女羞羞视频在线免费观看 | 亚洲1区 | 麻豆av一区二区三区久久 | 国产一区二| 中文字幕99 | 国产1区2区在线观看 | 96久久久久久 | 91麻豆蜜桃一区二区三区 | 超碰成人免费 | 影音先锋成人资源 | 美女黄网站 | 美日韩精品 | 日韩午夜一区二区三区 | 成人精品国产一区二区4080 | 色偷偷噜噜噜亚洲男人 | av无遮挡| 精品日韩电影 | 成人免费精品视频 | 亚洲国产中文在线 | 91精品国产91久久综合桃花 | 国产精品1 | 日韩久久精品 | 久久中文字幕一区 | a级片www| 青青草一区二区 | www.国产精品 | 精品欧美一区二区三区久久久小说 | 欧美亚洲视频 | 国产精品一区二区三区在线 |