中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java冒泡排序算法怎么用

發布時間:2022-01-06 14:51:55 來源:億速云 閱讀:133 作者:iii 欄目:大數據

這篇文章主要講解了“java冒泡排序算法怎么用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java冒泡排序算法怎么用”吧!

       冒泡排序是一種簡單的排序算法。它重復地走訪過要排序的數列,一次比較兩個元素,如果它們的順序錯誤就把它們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個算法的名字由來是因為越小的元素會經由交換慢慢“浮”到數列的頂端。 

1.1 算法描述

  • 比較相鄰的元素。如果第一個比第二個大,就交換它們兩個;

  • 對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最后一對,這樣在最后的元素應該會是最大的數;

  • 針對所有的元素重復以上的步驟,除了最后一個;

  • 重復步驟1~3,直到排序完成。


java冒泡排序算法怎么用

 1/**
2 * @description: 冒泡排序
3 * 冒泡排序只會操作相鄰的兩個數據。每次冒泡操作都會對相鄰的兩個元素進行比較,看是否滿足大小關系要求。
4 * 如果不滿足就讓它倆互換。一次冒泡會讓至少一個元素移動到它應該在的位置,重復n 次,
5 * 就完成了 n 個數據的排序工作。
6 **/
7public class BubbleSort {
8    public void bubbleSort(Integer[] arr, int n) {
9        if (n <= 1) return;       //如果只有一個元素就不用排序了
10
11        for (int i = 0; i < n; ++i) {
12            // 提前退出冒泡循環的標志位,即一次比較中沒有交換任何元素,這個數組就已經是有序的了
13            boolean flag = false;
14            for (int j = 0; j < n - i - 1; ++j) {        //此處你可能會疑問的j<n-i-1,因為冒泡是把每輪循環中較大的數飄到后面,
15                // 數組下標又是從0開始的,i下標后面已經排序的個數就得多減1,總結就是i增多少,j的循環位置減多少
16                if (arr[j] > arr[j + 1]) {        //即這兩個相鄰的數是逆序的,交換
17                    int temp = arr[j];
18                    arr[j] = arr[j + 1];
19                    arr[j + 1] = temp;
20                    flag = true;
21                }
22            }
23            if (!flag) break;//沒有數據交換,數組已經有序,退出排序
24        }
25    }

1.2 時間復雜度:

  • 如果我們的數據正序,只需要走一趟即可完成排序。所需的比較次數C和記錄移動次數M均達到最小值,

即:Cmin=n-1;Mmin=0;所以,冒泡排序最好的時間復雜度為O(n)。

  • 如果很不幸我們的數據是反序的,則需要進行n-1趟排序。每趟排序要進行n-i次比較(1≤i≤n-1),且每次比較都必須移動記錄三次來達到交換記錄位置。在這種情況下,比較和移動次數均達到最大值:

java冒泡排序算法怎么用

即最壞情況下時間復雜度為O(n2)【n的平方】;

  • 所以,冒泡排序總的平均時間復雜度為:O(n2) 。

感謝各位的閱讀,以上就是“java冒泡排序算法怎么用”的內容了,經過本文的學習后,相信大家對java冒泡排序算法怎么用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵寿县| 河津市| 贡嘎县| 满城县| 浦东新区| 永嘉县| 温宿县| 平昌县| 碌曲县| 商城县| 柘城县| 乐都县| 河北区| 博兴县| 革吉县| 静乐县| 通城县| 普定县| 曲周县| 彭泽县| 福安市| 织金县| 甘洛县| 揭东县| 巴南区| 钟山县| 大邑县| 新津县| 南宁市| 铁岭市| 吐鲁番市| 宁陕县| 嘉禾县| 土默特右旗| 句容市| 灵武市| 台山市| 长海县| 万荣县| 莱西市| 南华县|