一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java排序算法總結之冒泡排序

Java排序算法總結之冒泡排序

2019-12-18 16:25一羽清寧 JAVA教程

這篇文章主要介紹了Java排序算法總結之冒泡排序,較為詳細的分析了冒泡排序的原理與java實現技巧,需要的朋友可以參考下

本文實例講述了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
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// 冒泡排序  
public class BubbleSort{
  public static void sort(Comparable[] data){
    // 數組長度
    int len = data.length;
    for (int i = 0; i < len - 1; i++){
      // 臨時變量
      Comparable temp = null;
      // 交換標志,false表示未交換
      boolean isExchanged = false;
      for (int j = len - 1; j > i; j--){
        // 如果data[j]小于data[j - 1],交換
        if (data[j].compareTo(data[j - 1]) < 0){
          temp = data[j];
          data[j] = data[j - 1];
          data[j - 1] = temp;
          // 發生了交換,故將交換標志置為真
          isExchanged = true;
        }// end if
      }// end for
      // 本趟排序未發生交換,提前終止算法,提高效率
      if (!isExchanged){
        return;
      }// end if
    }// end for
  }// end sort
  public static void main(String[] args){
    // 在JDK1.5版本以上,基本數據類型可以自動裝箱
    // int,double等基本類型的包裝類已實現了Comparable接口
    Comparable[] c = { 4, 9, 23, 1, 45, 27, 5, 2 };
    sort(c);
    for (Comparable data : c){
      System.out.println(data);
    }
  }
}

使用冒泡排序法對n個數據進行排序,共需要進行n-1次的比較。如果本來就是有順序的數據,也需要進行n-1次比較。冒泡排序法的算法很簡單,效率也較差。

希望本文所述對大家的java程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91久久精品国产亚洲 | 亚洲高清一区二区三区久久 | 四虎884aa永久播放地址http | 无码爽死成人777在线观看网站 | 国产亚洲精aa在线观看不卡 | 日日草视频 | 日本aaaaa高清免费看 | 国产午夜精品福利久久 | 久久中文字幕无线观看 | 亚洲第一二三四区 | 亚洲欧美视频在线播放 | 高h肉爽文农民工 | 婷婷激情综合五月天 | 99热在线精品播放 | 美女又爽又黄免费 | 国产成人精品一区二三区2022 | 2021日产国产麻豆 | 四虎永久在线精品国产 | 日本中文字幕一区二区高清在线 | 99热在线精品播放 | 91精品大神国产在线播放 | 亚洲无限 | 99在线在线视频免费视频观看 | 国产麻豆精品入口在线观看 | www在线看| 国产原创一区二区 | 男人把大ji巴放进男人免费视频 | 成人小视频在线免费观看 | 亚洲精品www久久久久久久软件 | 亚洲精品第五页中文字幕 | 无码AV免费精品一区二区三区 | 韩国理论三级在线观看视频 | 国产精品在线 | java hd国产高清 | 美女张开腿让男人桶的 视频 | 99年水嫩漂亮粉嫩在线播放 | 精新精新国产自在现拍 | 美艳教师刘艳第三部166 | 我的妹妹最近有点怪在线观看 | 青青青青青国产费线在线观看 | 日韩精品一区二三区中文 |