日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

冒泡算法是一種簡單的排序算法,它的基本思想是通過相鄰元素之間的比較和交換,將大的元素慢慢地“冒泡”到數組的最后一個位置。冒泡算法在實現上非常簡單,但它的時間復雜度較高,通常僅適用于小型數據集的排序。

一、算法原理

冒泡算法的原理非常簡單:首先將要排序的數列分成兩部分,已排序的部分和未排序的部分。每一輪排序中,從第一個元素開始,依次比較相鄰的兩個元素,如果前一個元素大于后一個元素,則交換兩個元素的位置,直到整個數列都排好序為止。

假設要排序的數列為A[],其長度為n。則第一輪排序時需要比較n-1次,第二輪排序時需要比較n-2次,以此類推,第k輪排序時需要比較n-k次。因此,總共需要進行n(n-1)/2次比較,時間復雜度為O(n^2)。

二、算法流程

具體來說,冒泡算法的流程如下:

1、首先,將要排序的數列A[]作為輸入,其長度為n;

2、然后,從第一個元素開始,依次比較相鄰的兩個元素,如果前一個元素大于后一個元素,則交換兩個元素的位置;

3、接著,將指針向后移動一位,繼續(xù)比較相鄰的兩個元素,并進行交換,直到整個數列都排好序為止;

4、最后,輸出已排序的數列A[]。

三、優(yōu)化算法

冒泡排序的時間復雜度為O(n^2),當數據量較大時,會出現比較耗費時間的情況。因此,我們可以進行一些優(yōu)化,使得算法的效率更高。

1、當在某一輪排序中,沒有任何一次交換操作發(fā)生時,表示數列已經有序,此時可以直接退出循環(huán)。

2、在排序過程中,記錄最后一次發(fā)生交換的位置,之后的數列都已排好序,因此可以減少比較次數:

public class BubbleSortAnimation {

    public static void main(String[] args) {
        int[] arr = {10, 2, 1, 42, 22, 8, 9, 11, 1, 4, 6, 33, 20, 11, 17, 55, 24};
        int n = arr.length;
        int lastExchange = 0; // 最后一次交換位置
        int sortBorder = n - 1; // 無序數列的邊界
        for (int i = 0; i < n - 1; i++) {
            boolean flag = true; // 標記是否發(fā)生交換
            for (int j = 0; j < sortBorder; j++) {
                if (arr[j] > arr[j + 1]) {
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                    flag = false; // 發(fā)生交換
                    lastExchange = j; // 記錄最后一次交換位置
                }
            }

            // 打印每一輪排序后的數組情況
            System.out.print("第 " + (i + 1) + " 輪排序后的數組為:");
            for (int k = 0; k < n; k++) {
                System.out.print(arr[k] + " ");
            }
            System.out.println();

            sortBorder = lastExchange; // 更新無序數列的邊界
            if (flag) {
                break; // 本輪排序未發(fā)生交換,說明已有序
            }
        }
    }
}
  • 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.

示例代碼的輸出日志:

第 1 輪排序后的數組為:2 1 10 22 8 9 11 1 4 6 33 20 11 17 42 24 55 
第 2 輪排序后的數組為:1 2 10 8 9 11 1 4 6 22 20 11 17 33 24 42 55 
第 3 輪排序后的數組為:1 2 8 9 10 1 4 6 11 20 11 17 22 24 33 42 55 
第 4 輪排序后的數組為:1 2 8 9 1 4 6 10 11 11 17 20 22 24 33 42 55 
第 5 輪排序后的數組為:1 2 8 1 4 6 9 10 11 11 17 20 22 24 33 42 55 
第 6 輪排序后的數組為:1 2 1 4 6 8 9 10 11 11 17 20 22 24 33 42 55 
第 7 輪排序后的數組為:1 1 2 4 6 8 9 10 11 11 17 20 22 24 33 42 55 
第 8 輪排序后的數組為:1 1 2 4 6 8 9 10 11 11 17 20 22 24 33 42 55
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.

動圖效果:

冒泡排序過程演示,若無法顯示動圖請刷新重試

四、算法分析

1、時間復雜度:最好情況下為O(n),即數列已經排序完成,無需進行任何比較操作;最壞情況下為O(n^2);平均情況下為O(n^2)。

2、空間復雜度:由于只需要一個額外的變量來保存臨時變量,并沒有使用任何額外的空間,空間復雜度為O(1)。

3、穩(wěn)定性:冒泡排序是一種穩(wěn)定排序算法,因為在比較相鄰的兩個元素時,只有在前一個元素大于后一個元素時才會進行交換,不會改變相同元素之間的順序。

五、總結

冒泡排序是一種簡單而又經典的排序算法,雖然其時間復雜度較高,但由于其實現簡單,易于理解,是許多排序算法中最為基礎的一種。在實際應用中,我們可以根據具體情況對其進行優(yōu)化,從而提高算法的效率。

分享到:
標簽:算法
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰(zhàn)2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定