欧美日韩不卡一区二区三区,www.蜜臀.com,高清国产一区二区三区四区五区,欧美日韩三级视频,欧美性综合,精品国产91久久久久久,99a精品视频在线观看

java語言

冒泡排序的原理以及java代碼實現(xiàn)

時間:2024-12-29 17:20:14 java語言 我要投稿
  • 相關(guān)推薦

冒泡排序的原理以及java代碼實現(xiàn)

  冒泡排序的原理以及java代碼實現(xiàn)

  概述

  冒泡排序是一種簡單的排序算法。

  它重復地走訪要排序的數(shù)列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數(shù)列的工作是重復地進行直到數(shù)列已經(jīng)排序完成。這個算法的名字由來是因為越小的元素會經(jīng)由交換慢慢“浮”到數(shù)列的開始。

  簡單點說,就是:

  冒泡排序是將比較大的數(shù)字沉在數(shù)組的后面(可以理解為下面),較小的浮在前面(上面)。

  直觀釋義圖:

  步驟

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

  對每一對相鄰元素作同樣的工作,從開始第一對到結(jié)尾的最后一對。在這一點,最后的元素應(yīng)該會是最大的`數(shù)。

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

  持續(xù)每次對越來越少的元素重復上面的步驟,直到?jīng)]有任何一對數(shù)字需要比較。

  實例

  原始數(shù)據(jù):

  3 5 2 6 2

  第一輪

  比較 3 和 5,5 大于 3 ,不需交換3 5 2 6 2繼續(xù)比較 5 和 2,5 大于 2,交換位置3 2 5 6 2繼續(xù)比較 5 和 6,6 大于 5,不需交換3 2 5 6 2繼續(xù)比較 6 和 2,6 大于 2,交換位置3 2 5 2 66 下沉到最后,兩個2都分別向上(前)冒出。

  第二輪

  比較 3 和 2, 3 大于 2,交換位置2 3 5 2 6比較 3 和 5, 5 大于 3,不需交換2 3 5 2 6比較 5 和 2, 5 大于 2,交換位置2 3 2 5 6不需比較 5 和 6

  第三輪

  比較 2 和 3, 3 大于 2,不需交換2 3 2 5 6比較 3 和 2, 3 大于 2,交換位置2 2 3 5 6不需比較了

  第四輪

  比較 2 和 2,不需交換2 2 3 5 6

  四輪結(jié)束

  2 2 3 5 6

  代碼實現(xiàn)(Java)

  package com.coder4j.main.arithmetic.sorting;public class Bubble { /** * 冒泡排序 * * @param array * @return */ public static int[] sort(int[] array) { int temp; // 第一層循環(huán)表明比較的輪數(shù), 比如 length 個元素,比較輪數(shù)為 length-1 次(不需和自己比) for (int i = 0; i < array.length - 1; i++) { System.out.println("第" + (i + 1) + "輪開始"); // 第二層循環(huán),每相鄰的兩個比較一次,次數(shù)隨著輪數(shù)的增加不斷減少,每輪確定一個最大的,不需比較那個最大的 for (int j = 0; j < array.length - 1 - i; j++) { if (array[j + 1] < array[j]) { temp = array[j]; array[j] = array[j + 1]; array[j + 1] = temp; } System.out.println("第" + (i + 1) + "輪,第" + (j + 1) + "次比較:"); for (int k : array) { System.out.print(k + " "); } System.out.println(); } System.out.println("結(jié)果:"); for (int k : array) { System.out.print(k + " "); } System.out.println(); } return array; } public static void main(String[] args) { int[] array = { 3, 5, 2, 6, 2 }; int[] sorted = sort(array); System.out.println("最終結(jié)果"); for (int i : sorted) { System.out.print(i + " "); } }}

  測試輸出結(jié)果:

  第1輪開始第1輪,第1次比較:3 5 2 6 2 第1輪,第2次比較:3 2 5 6 2 第1輪,第3次比較:3 2 5 6 2 第1輪,第4次比較:3 2 5 2 6 結(jié)果:3 2 5 2 6 第2輪開始第2輪,第1次比較:2 3 5 2 6 第2輪,第2次比較:2 3 5 2 6 第2輪,第3次比較:2 3 2 5 6 結(jié)果:2 3 2 5 6 第3輪開始第3輪,第1次比較:2 3 2 5 6 第3輪,第2次比較:2 2 3 5 6 結(jié)果:2 2 3 5 6 第4輪開始第4輪,第1次比較:2 2 3 5 6 結(jié)果:2 2 3 5 6 最終結(jié)果2 2 3 5 6

  經(jīng)測試,與實例中結(jié)果一致。

【冒泡排序的原理以及java代碼實現(xiàn)】相關(guān)文章:

冒泡排序算法原理及JAVA實現(xiàn)代碼方法10-16

Java 隊列實現(xiàn)原理及簡單實現(xiàn)代碼09-13

java常見的排序算法的代碼09-20

冒泡排序(C語言實現(xiàn))08-30

java利用反射實現(xiàn)動態(tài)代理實現(xiàn)代碼10-08

java實現(xiàn)gif動畫效果代碼參考07-23

java構(gòu)造函數(shù)實現(xiàn)代碼示例08-23

教你JAVA語言快速排序的原理10-04

java插入法排序原理06-03