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

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

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

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

java 排序算法之冒泡排序

2021-12-14 13:07天然呆dull Java教程

這篇文章主要介紹了java 排序算法之冒泡排序,文中運用大量的代碼講解相關知識,非常詳細,感興趣的小伙伴可以參考一下

 

基本介紹

冒泡排序(Bubble Sorting)(時間復雜度為 O(n²))的基本思想:通過對待排序序列 從前向后(從下標較小的元素開始),依次比較相鄰元素的值,若發現逆序則交換,使值較大的元素逐漸從前移向后部,就像水底下的旗袍一樣逐漸向上冒。

優化點:因為排序過程中,個元素不斷接近自己的位置,如果一趟比較下來沒有進行過交換,就說明序列有序,因此要在排序過程中設置一個標志判斷元素是否進行過交換。從而減少不必要的比較。(該優化點可以在完成基本的冒泡排序之后再做)

 

圖解冒泡排序算法的過程

java 排序算法之冒泡排序

動圖:

java 排序算法之冒泡排序

冒泡排序小結:

1.共進行 數組大小 - 1 次大的循環

2.每一趟排序的次數在逐漸的減少

3.優化:如果發現在某趟排序中,沒有發生一次交換,則可以提前結束冒泡排序。

 

代碼實現

 

演變過程

為了容易理解,先演示冒泡排序的演變過程

    /**
     * 為了更好的理解,這里把冒泡排序的演變過程演示出來
     */
    @Test
    public void processDemo() {
        int arr[] = {3, 9, -1, 10, -2};

        // 第 1 趟排序:將最大的數排在最后
        // 總共排序:arr.length - 1
        int temp = 0; // 臨時變量,交換的時候使用
        for (int i = 0; i < arr.length - 1; i++) {
            if (arr[i] > arr[i + 1]) {
                temp = arr[i];
                arr[i] = arr[i + 1];
                arr[i + 1] = temp;
            }
        }
        System.out.println("第 1 趟排序后的數組");
        System.out.println(Arrays.toString(arr));

        // 第 2 趟排序:將第 2 大的數排在倒數第 2 位
        // 總共排序:arr.length - 1 - 1  ;
        // 從頭開始排序,其他沒有變化,只是將排序次數減少了一次
        for (int i = 0; i < arr.length - 1 -1; i++) {
            if (arr[i] > arr[i + 1]) {
                temp = arr[i];
                arr[i] = arr[i + 1];
                arr[i + 1] = temp;
            }
        }
        System.out.println("第 2 趟排序后的數組");
        System.out.println(Arrays.toString(arr));

        // 第 3 趟排序:將第 3 大的數排在倒數第 3 位
        // 總共排序:arr.length - 1 - 2  ;
        // 從頭開始排序,其他沒有變化,只是將排序次數減少了 2 次
        for (int i = 0; i < arr.length - 1 -2; i++) {
            if (arr[i] > arr[i + 1]) {
                temp = arr[i];
                arr[i] = arr[i + 1];
                arr[i + 1] = temp;
            }
        }
        System.out.println("第 3 趟排序后的數組");
        System.out.println(Arrays.toString(arr));

        // 第 4 趟排序:將第 4 大的數排在倒數第 4 位
        // 總共排序:arr.length - 1 - 3  ;
        // 從頭開始排序,其他沒有變化,只是將排序次數減少了 3 次
        for (int i = 0; i < arr.length - 1 -3; i++) {
            if (arr[i] > arr[i + 1]) {
                temp = arr[i];
                arr[i] = arr[i + 1];
                arr[i + 1] = temp;
            }
        }
        System.out.println("第 4 趟排序后的數組");
        System.out.println(Arrays.toString(arr));

        // 第 5 趟沒有必要,因為這里有 5 個數字,確定了 4 個數字,剩下的那一個就已經出來了
    }

測試輸出

第 1 趟排序后的數組
[3, -1, 9, -2, 10]
第 2 趟排序后的數組
[-1, 3, -2, 9, 10]
第 3 趟排序后的數組
[-1, -2, 3, 9, 10]
第 4 趟排序后的數組
[-2, -1, 3, 9, 10]

從上述的 4 趟排序過程來看,循環體都是一樣的,只是每次循環的次數在減少,那么就可以如下簡化

@Test
public void processDemo2() {
  int arr[] = {3, 9, -1, 10, -2};

  // 總共排序:arr.length - 1
  int temp = 0; // 臨時變量,交換的時候使用
  for (int j = 0; j < arr.length - 1; j++) {
    for (int i = 0; i < arr.length - 1 - j; i++) {
      if (arr[i] > arr[i + 1]) {
        temp = arr[i];
        arr[i] = arr[i + 1];
        arr[i + 1] = temp;
      }
    }
    System.out.println("第 " + (j + 1) + " 趟排序后的數組");
    System.out.println(Arrays.toString(arr));
  }
}

測試輸出

第 1 趟排序后的數組
[3, -1, 9, -2, 10]
第 2 趟排序后的數組
[-1, 3, -2, 9, 10]
第 3 趟排序后的數組
[-1, -2, 3, 9, 10]
第 4 趟排序后的數組
[-2, -1, 3, 9, 10]

 

優化

對于優化,減少排序次數

    @Test
    public void processDemo3() {
        int arr[] = {3, 9, -1, 10, 20};

        // 總共排序:arr.length - 1
        int temp = 0; // 臨時變量,交換的時候使用
        boolean change = false;// 標識變量,表示是否進行過交換
        for (int j = 0; j < arr.length - 1; j++) {
            for (int i = 0; i < arr.length - 1 - j; i++) {
                if (arr[i] > arr[i + 1]) {
                    temp = arr[i];
                    arr[i] = arr[i + 1];
                    arr[i + 1] = temp;
                    change = true;
                }
            }
            if(!change){
                // 如果有 1 輪下來,都沒有進行排序,則可以提前退出
                break;
            }else{
                change = false; // 重置 change!!!, 進行下次判斷
            }
            System.out.println("第 " + (j + 1) + " 趟排序后的數組");
            System.out.println(Arrays.toString(arr));
        }
    }

測試輸出:

第 1 趟排序后的數組
[3, -1, 9, 10, 20]
第 2 趟排序后的數組
[-1, 3, 9, 10, 20]

這里更改了原始數組,因為優化的點,得看你這個數組原來的排序 和 元素組成,算是一種概率問題,并不是在任何情況下都可以被優化

 

封裝算法

    /**
     * 把排序算法封裝成一個方法,方便被復用
     *
     * @param arr
     */
    public static void bubbleSort(int[] arr) {
        // 總共排序:arr.length - 1
        int temp = 0; // 臨時變量,交換的時候使用
        boolean change = false;
        for (int j = 0; j < arr.length - 1; j++) {
            for (int i = 0; i < arr.length - 1 - j; i++) {
                if (arr[i] > arr[i + 1]) {
                    temp = arr[i];
                    arr[i] = arr[i + 1];
                    arr[i + 1] = temp;
                    change = true;
                }
            }
            if(!change){
                // 如果有 1 輪下來,都沒有進行排序,則可以提前退出
                break;
            }else{
                change = false; // 重置 change!!!, 進行下次判斷
            }
        }
    }

測試調用

    /**
     * 測試封裝后的算法
     */
    @Test
    public void bubbleSortTest() {
        int[] arr = {3, 9, -1, 10, 20};
        System.out.println("排序前:" + Arrays.toString(arr));
        bubbleSort(arr);
        System.out.println("排序后:" + Arrays.toString(arr));
    }
    

測試輸出

排序前:[3, 9, -1, 10, 20]
排序后:[-1, 3, 9, 10, 20]

 

大量數據耗時測試

排序隨機生成的 8 萬個數據

    /**
     * 大量數據排序時間測試
     */
    @Test
    public void bulkDataSort() {
        int max = 80000;
        int[] arr = new int[max];
        for (int i = 0; i < max; i++) {
            arr[i] = (int) (Math.random() * 80000);
        }

        Instant startTime = Instant.now();
        bubbleSort(arr);
//        System.out.println(Arrays.toString(arr));
        Instant endTime = Instant.now();
        System.out.println("共耗時:" + Duration.between(startTime, endTime).toMillis() + " 毫秒");
    }

測試輸出

運行幾次,差不多在 13 秒左右
共耗時:14656 毫秒
共耗時:13853 毫秒

到此這篇關于java 排序算法之冒泡排序的文章就介紹到這了,更多相關java 冒泡排序內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/ljz111/p/15203778.html

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 国产精品免费_区二区三区观看 | 久久三级视频 | 能免费观看的韩剧 | 国产欧美日韩精品一区二区三区 | 国产成人99久久亚洲综合精品 | 99视频全部免费 | 国产一级精品高清一级毛片 | 日本ccc三级 | 无人区在线观看免费视频国语 | 亚洲高清在线天堂精品 | 2021国产精品视频 | 国产激情在线 | 国产亚洲人成网站天堂岛 | 久久99热狠狠色AV蜜臀 | 77色视频在线 | 日韩精品一区二区三区毛片 | 莫莉瑞典1977k | 日本免费看 | 免费永久视频 | 免费看60分钟大片视频播放 | 操大肥b | 91精品啪在线观看国产日本 | 久久视频在线视频观看精品15 | 美女张开腿黄网站免费精品动漫 | 午夜欧美精品久久久久久久久 | 国产精品视频在线观看 | 成人香蕉xxxxxxx | 日本免费久久久久久久网站 | 毛片亚洲毛片亚洲毛片 | 国产成人无精品久久久久国语 | 亚洲色欲色欲综合网站 | 九九九九在线精品免费视频 | 国内精品久久久久久久 | 99re5精品视频在线观看 | 欧亚尺码专线欧洲s码wmy | 高h全肉动漫在线观看免费 高h辣h双处全是肉军婚 | 国产成人夜色91 | 1024日韩基地 | 二次元美女脱裤子让男人桶爽 | 操碰人人 | 4438全国最大免费观看 |