使用原生Java怎么樣實現一個冒泡排序算法?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
需求: 給定數組,ary=[2,4,5,3,1], 如何升序或逆序排列?
提示: Arrays.sort只能升序排列, 先用雙重for循環,原生方法實現.
public class T02 {
public static void main(String[] args) {
//冒泡升序
int [] ary = {1,4,5,6,7,8,3,2};
for (int i = 0; i <ary.length ; i++) {
for (int j = (i+1); j <ary.length ; j++) {
if (ary[i]>ary[j]){
// 交換兩者的值
int c = ary[i];
ary[i] = ary[j];
ary[j] = c;
}
}
}
// 寫在雙重for循環外面
for (int i1 : ary) {
System.out.print(i1);
}
}
}打印結果: 12345678
降序的實現只需要更改 if( ) 中條件,讓 ary[i] < ary[j] 即可.
簡便方法:
利用Arrays.sort數組方法實現升序:
代碼如下:
// Array.sort排序
int [] ary = {2,4,1,3,5,6,8,7,9};
Arrays.sort(ary);
for (int i1 : ary) {
System.out.print(i1);
}
System.out.println();
// 倒序排列,沒有方法
for (int i = ary.length-1; i > -1 ; i--) {
System.out.print(ary[i]);
}
System.out.println();輸出結果:
-----------------升序:123456789
-----------------降序:987654321
輸出截圖:

關于使用原生Java怎么樣實現一個冒泡排序算法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。