Java冒泡排序的定義與實例代碼
冒泡排序
在八大排序中,冒泡排序是最為出名的排序算法之一!
冒泡排序的代碼還是相當(dāng)簡單的,兩層循環(huán),外層是冒泡輪數(shù),里層是依次比較,這個算法的時間復(fù)雜度為O(n2);
冒泡排序的思想:
- 比較數(shù)組中相鄰的兩個元素,如果第一個數(shù)比第二個數(shù)大,就交換它們的位置
- 每一次比較都會產(chǎn)生一個最大或最小的元素
- 下一次循環(huán)就只排序剩下的元素
- 依次循環(huán),直到所有元素排序完成
通過實例理解:
public static void main(String[] args) {
int[] a={55,45,33,24,78,65,11};
int[] sort = sorts(a);
System.out.println(Arrays.toString(sort));
}
public static int[] sorts(int[] array){
int a=0;
//外層循環(huán),判斷要循環(huán)的次數(shù),記錄不需要比較的元素的個數(shù);
//在內(nèi)層循環(huán)結(jié)束后,除去得到的元素,再重新讓內(nèi)層循環(huán)排序剩余的元素。
for (int i=0;i<array.length-1;i++){
/**
* 內(nèi)層循環(huán),把每個相鄰的元素比較一遍,后一個數(shù)大就交換位置,得到一個最小的元素,位于數(shù)組的最后。
* j<array.length-1-i的意思是每把外層for循環(huán)走一次,內(nèi)層for循環(huán)就得到一個相對最小的元素,
* 那么下次循環(huán)就不再比較它,所以要—i
* if語句是要把最小的元素放到array[j+1],這樣數(shù)組就會從大到小排列
*/
for (int j=0;j<array.length-1-i;j++){
if (array[j+1]>array[j]){
a=array[j];
array[j]=array[j+1];
array[j+1]=a;
}
}
}
return array;
}
運行結(jié)果:

總結(jié)
到此這篇關(guān)于Java冒泡排序的定義與實例的文章就介紹到這了,更多相關(guān)Java冒泡排序的定義與實例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java使用ArrayList實現(xiàn)斗地主(無序版)
這篇文章主要為大家詳細(xì)介紹了java使用ArrayList實現(xiàn)斗地主,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-03-03
SpringBoot中EasyExcel實現(xiàn)execl導(dǎo)入導(dǎo)出
本文主要介紹了SpringBoot中EasyExcel實現(xiàn)execl導(dǎo)入導(dǎo)出,實現(xiàn)了如何準(zhǔn)備環(huán)境、創(chuàng)建實體類、自定義轉(zhuǎn)換器以及編寫導(dǎo)入邏輯的步驟和示例代碼,感興趣的可以了解下2023-06-06
解決SpringBoot項目讀取yml文件中值為中文時,在視圖頁面顯示亂碼
這篇文章主要介紹了解決SpringBoot項目讀取yml文件中值為中文時,在視圖頁面顯示亂碼的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08
解析SpringSecurity自定義登錄驗證成功與失敗的結(jié)果處理問題
這篇文章主要介紹了SpringSecurity系列之自定義登錄驗證成功與失敗的結(jié)果處理問題,本文通過實例給大家講解的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11
關(guān)于String轉(zhuǎn)Json的幾種方式
這篇文章主要介紹了關(guān)于String轉(zhuǎn)Json的幾種方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12

