冒泡排序(Bubble Sort)是常用的數(shù)組排序算法之一,它以簡潔的思想與實現(xiàn)方法而備受青睞,也是廣大學(xué)習(xí)者最先接觸的一種排序算法。
冒泡排序的基本思想是:對比相鄰的元素值,如果滿足條件就交換元素值,把較小的元素值移動到數(shù)組前面,把大的元素值移動到數(shù)組后面(也就是交換兩個元素的位置),這樣數(shù)組元素就像氣泡一樣從底部上升到頂部。
冒泡排序的算法比較簡單,排序的結(jié)果穩(wěn)定,但時間效率不太高。Java 中的冒泡排序在雙層循環(huán)中實現(xiàn),其中外層循環(huán)控制排序輪數(shù),總循環(huán)次數(shù)為要排序數(shù)組的長度減 1。而內(nèi)層循環(huán)主要用于對比相鄰元素的大小,以確定是否交換位置,對比和交換次數(shù)依排序輪數(shù)而減少。
例 1
獲取用戶在控制臺輸入的 5 個成績信息,將這些成績保存到數(shù)組中,然后對數(shù)組應(yīng)用冒泡排序,并輸出排序后的結(jié)果,實現(xiàn)步驟如下。
(1) 創(chuàng)建一個 Test24 類文件,在 main() 方法中開始編碼。首先創(chuàng)建 Scanner 類的實例后聲明 double 類型的 score 數(shù)組,然后接收用戶在控制臺輸入的成績,并保存到元素中。代碼如下:
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
double[] score = new double[5];
for (int i = 0; i < score.length; i++) {
System.out.print("請輸入第 " + (i + 1) + " 個成績:");
score[i] = scan.nextDouble();
}
填寫下面表單即可預(yù)約申請免費試聽java課程!害怕學(xué)不會?助教陪讀,隨時解惑!擔(dān)心就業(yè)?一地學(xué)習(xí),可全國推薦就業(yè)!
}
(2) 在對 score 數(shù)組排序之前,首先輸出數(shù)組中各個元素的值。代碼如下:
System.out.println("排序前的元素值:");
for(double val:score) {
System.out.print(val+"\t");
}
System.out.println();
(3) 通過冒泡排序方法實現(xiàn)對 score 數(shù)組的排序,在實現(xiàn)時需要借助一個臨時變量。代碼如下:
public static void main(String[] args) {
System.out.println("通過冒泡排序方法對數(shù)組進行排序:");
for (int i = 0; i < score.length - 1; i++) {
// 比較相鄰兩個元素,較大的數(shù)往后冒泡
for (int j = 0; j < score.length - 1 - i; j++) {
if (score[j] > score[j + 1]) {
double temp = score[j + 1]; // 把第 一個元素值保存到臨時變量中
score[j + 1] = score[j]; // 把第二個元素值轉(zhuǎn)移到第 一個元素變量中
score[j] = temp; // 把臨時變量(第 一個元素的原值)保存到第二個元素中
}
System.out.print(score[j] + " "); // 對排序后的數(shù)組元素進行輸出
}
System.out.print("【");
for (int j = score.length - 1 - i; j < score.length; j++) {
System.out.print(score[j] + " ");
}
System.out.println("】");
}
}
(4) 運行前面的代碼進行測試,如下所示。
請輸入第 1 個成績:77
請輸入第 2 個成績:90
請輸入第 3 個成績:68
請輸入第 4 個成績:59
請輸入第 5 個成績:80
排序前的元素值:
77.0 90.0 68.0 59.0 80.0
通過冒泡排序方法對數(shù)組進行排序:
77.0 68.0 59.0 80.0 【90.0 】
68.0 59.0 77.0 【80.0 90.0 】
59.0 68.0 【77.0 80.0 90.0 】
59.0 【68.0 77.0 80.0 90.0 】
上一篇:Java選擇排序法
下一篇: 沒有了
初級會計職稱中級會計職稱經(jīng)濟師注冊會計師證券從業(yè)銀行從業(yè)會計實操統(tǒng)計師審計師高級會計師基金從業(yè)資格稅務(wù)師資產(chǎn)評估師國際內(nèi)審師ACCA/CAT價格鑒證師統(tǒng)計資格從業(yè)
一級建造師二級建造師消防工程師造價工程師土建職稱房地產(chǎn)經(jīng)紀(jì)人公路檢測工程師建筑八大員注冊建筑師二級造價師監(jiān)理工程師咨詢工程師房地產(chǎn)估價師 城鄉(xiāng)規(guī)劃師結(jié)構(gòu)工程師巖土工程師安全工程師設(shè)備監(jiān)理師環(huán)境影響評價土地登記代理公路造價師公路監(jiān)理師化工工程師暖通工程師給排水工程師計量工程師
人力資源考試教師資格考試出版專業(yè)資格健康管理師導(dǎo)游考試社會工作者司法考試職稱計算機營養(yǎng)師心理咨詢師育嬰師事業(yè)單位教師招聘公務(wù)員公選考試招警考試選調(diào)生村官
執(zhí)業(yè)藥師執(zhí)業(yè)醫(yī)師衛(wèi)生資格考試衛(wèi)生高級職稱護士資格證初級護師主管護師住院醫(yī)師臨床執(zhí)業(yè)醫(yī)師臨床助理醫(yī)師中醫(yī)執(zhí)業(yè)醫(yī)師中醫(yī)助理醫(yī)師中西醫(yī)醫(yī)師中西醫(yī)助理口腔執(zhí)業(yè)醫(yī)師口腔助理醫(yī)師公共衛(wèi)生醫(yī)師公衛(wèi)助理醫(yī)師實踐技能內(nèi)科主治醫(yī)師外科主治醫(yī)師中醫(yī)內(nèi)科主治兒科主治醫(yī)師婦產(chǎn)科醫(yī)師西藥士/師中藥士/師臨床檢驗技師臨床醫(yī)學(xué)理論中醫(yī)理論