亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

圖解Java經(jīng)典算法冒泡排序的原理與實(shí)現(xiàn)

 更新時(shí)間:2022年09月09日 16:06:19   作者:Binaire-沐辰  
冒泡排序是一種簡單的排序算法,它也是一種穩(wěn)定排序算法。其實(shí)現(xiàn)原理是重復(fù)掃描待排序序列,并比較每一對相鄰的元素,當(dāng)該對元素順序不正確時(shí)進(jìn)行交換。一直重復(fù)這個(gè)過程,直到?jīng)]有任何兩個(gè)相鄰元素可以交換,就表明完成了排序

冒泡排序

冒泡排序是一種比較簡單的排序算法,我們可以重復(fù)遍歷要排序的序列,每次比較兩個(gè)元素,如果他們順序錯(cuò)誤就交換位置,重復(fù)遍歷到?jīng)]有可以交換的元素,說明排序完成。

算法原理

  • 從第一個(gè)元素開始,比較相鄰的兩個(gè)元素,如果第一個(gè)大于第二個(gè),則交換它們
  • 對每一對相鄰的元素做相同的操作,從第一對到最后一對,最終最后一位元素就是最大值
  • 對每一個(gè)元素重復(fù)上述步驟,最后一個(gè)除外 

動(dòng)圖演示

算法練習(xí)

題目描述: 給定一個(gè)無序數(shù)組,利用冒泡排序?qū)?shù)組按升序排列。

示例一:

輸入: arrs= [5,0,9,3,-1,12]
輸出: arrs= [-1,0,3,5,9,12]

示例二:

輸入: arrs= [3,5,9,7,2,1]
輸出: arrs= [1,2,3,5,7,9]

解題思路:

通過比較相鄰的元素,如果前一個(gè)比后一個(gè)大,則交換位置。

  • 第一趟:比較第1個(gè)和第2個(gè)元素,然后是第2個(gè)和第3個(gè)比較,這樣直到倒數(shù)第2個(gè)和最后1個(gè),將最大的數(shù)移動(dòng)到最后一位。
  • 第二趟:重復(fù)上面步驟,將第二大的數(shù)交換至倒數(shù)第二位。

  • 每一趟都會(huì)將元素中第 n 大的元素交換到倒數(shù)第 n 位。
  • 一共需要n-1趟。

代碼實(shí)現(xiàn):

public class BubbleTest {
    public static void main(String[] args) {
        Integer[] arr = {3,5,9,7,2,1};
        Bubble.sort(arr);
        System.out.println(Arrays.toString(arr));
    }
    //數(shù)組排序
    public static void bubblesort(Comparable[] a){
        for (int i = a.length - 1;i > 0;i--){
            for (int j = 0;j < i;j++){
                if (greater(a[j],a[j + 1])){
                    swap(a,j,j + 1);
                }
            }
        }
    }
    //比較 v 是否大于 w
    public static boolean greater(Comparable v,Comparable w){
        return v.compareTo(w) > 0;
    }
    //數(shù)組元素交換位置
    private static void swap(Comparable[] a,int i,int j){
        Comparable temp;
        temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}

算法分析

時(shí)間復(fù)雜度

冒泡排序是一種用時(shí)間換空間的排序方法,最壞情況是把順序的排列變成逆序,或者把逆序的數(shù)列變成順序。在這種情況下,每一次比較都需要進(jìn)行交換運(yùn)算。

而對于有n個(gè)元素的數(shù)列它的比較次數(shù)為 (n-1) + (n-2) + … + 1 = n * (n - 1) / 2;因此它的時(shí)間復(fù)雜度為O(n^2)。

空間復(fù)雜度

冒泡排序的輔助變量只是一個(gè)臨時(shí)變量,不會(huì)隨數(shù)組規(guī)模的增大而增大,所以冒泡排序的空間復(fù)雜度為O(1)。

到此這篇關(guān)于圖解Java經(jīng)典算法冒泡排序的原理與實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Java冒泡排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • IDEA集成MyBatis Generator插件的使用

    IDEA集成MyBatis Generator插件的使用

    這篇文章主要介紹了IDEA集成MyBatis Generator插件的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 教你用Java實(shí)現(xiàn)一個(gè)簡單的代碼生成器

    教你用Java實(shí)現(xiàn)一個(gè)簡單的代碼生成器

    今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識(shí),文章圍繞著如何用Java實(shí)現(xiàn)一個(gè)簡單的代碼生成器展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • 詳解Java中ArrayList類

    詳解Java中ArrayList類

    這篇文章主要介紹了Java中ArrayList類,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • java 字符串截取的實(shí)例詳解

    java 字符串截取的實(shí)例詳解

    這篇文章主要介紹了java 字符串截取的實(shí)例詳解的相關(guān)資料,這里提供了實(shí)例代碼幫助大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-08-08
  • 在springboot中使用AOP進(jìn)行全局日志記錄

    在springboot中使用AOP進(jìn)行全局日志記錄

    這篇文章主要介紹就在springboot中使用AOP進(jìn)行全局日志記錄,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 深入了解MyBatis二級(jí)緩存

    深入了解MyBatis二級(jí)緩存

    今天小編就為大家分享一篇關(guān)于深入了解MyBatis二級(jí)緩存,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Java?Thread.currentThread().getName()?和?this.getName()區(qū)別詳解

    Java?Thread.currentThread().getName()?和?this.getName()區(qū)別詳

    本文主要介紹了Thread.currentThread().getName()?和?this.getName()區(qū)別詳解,TestThread?testThread?=?new?TestThread();
    2022-02-02
  • Java調(diào)用opencv實(shí)現(xiàn)圖片矯正功能

    Java調(diào)用opencv實(shí)現(xiàn)圖片矯正功能

    這篇文章主要為大家詳細(xì)介紹了Java如何調(diào)用opencv實(shí)現(xiàn)圖片矯正功能,文中的示例代碼簡潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-09-09
  • java-jsp springmvc-controller 傳值到頁面的方法

    java-jsp springmvc-controller 傳值到頁面的方法

    下面小編就為大家分享一篇java-jsp springmvc-controller 傳值到頁面的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • java設(shè)計(jì)模式學(xué)習(xí)之代理模式

    java設(shè)計(jì)模式學(xué)習(xí)之代理模式

    這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)模式學(xué)習(xí)之代理模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10

最新評(píng)論