氣泡排序java實現

zhumeilu發表於2017-12-14

資料結構中的幾個排序氣泡排序算是最簡單的一個了,基本的思路就是從最開始的一個元素依次和後面的元素比較,如果後面的元素比較小,那就和第一個元素交換,就這樣,從第一個比較到最後一個. 程式碼實現:


/**
 * 氣泡排序
 */
public class BubbleSort {

    /**
     * 移動次數少,迴圈次數多
     * @param arr
     */
    public static void sort1(int[] arr){
        int times = 0;
        //依次遍歷整個陣列
        for (int i = 0; i < arr.length-1; i++) {
            //將當前的元素與後面的元素依次比較,如果後面的元素比較大,則交換位置
            for (int j = i+1; j < arr.length; j++) {
                times++;
                if(arr[i]>arr[j]){
                    int temp=arr[i];
                    arr[i]=arr[j];
                    arr[j] = temp;
                }
            }
        }

        System.out.println("sort1執行了"+times+"次");
    }

    public static void sort2(int[] arr){
        int times = 0;

        for (int i = 0; i < arr.length-1; i++) {

            for (int j = 0; j < arr.length-1-i; j++) {
                times++;
                if(arr[j]>arr[j+1]){
                    int temp=arr[j+1];
                    arr[j+1]=arr[j];
                    arr[j] = temp;
                }
            }
        }
        System.out.println("sort2執行了"+times+"次");
    }

    public static void sort3(int[] arr){
        int times = 0;
        boolean flag = true;
        for (int i = 0; i < arr.length-1; i++) {
            flag = true;
            for (int j = 0; j < arr.length-1-i; j++) {
                times++;
                if(arr[j]>arr[j+1]){
                    int temp=arr[j+1];
                    arr[j+1]=arr[j];
                    arr[j] = temp;
                    flag = false;
                }
            }
            if(flag)
                break;
        }
        System.out.println("sort3執行了"+times+"次");
    }


    public static void sort4(int[] arr){
        int times = 0;
        int flag = 0;
        int n = arr.length-1;
        for (int i = 0; i < arr.length-1; i++) {

            for (int j = 0; j < n; j++) {
                times++;
                if(arr[j]>arr[j+1]){
                    int temp=arr[j+1];
                    arr[j+1]=arr[j];
                    arr[j] = temp;
                    flag = j;
                }
            }
            n = flag;
            if(i>=n)
                break;
        }
        System.out.println("sort4執行了"+times+"次");
    }

    public static void print(int[] arr){
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+"\t");
        }
    }
    public static void main(String[] args) {
        int[] arr = {1,5,4,11, 18,20};
        sort1(arr);
        print(arr);
        System.out.println();

        int[] arr2 = {1,5,4,11, 18,20};
        sort2(arr2);
        print(arr2);
        System.out.println();

        int[] arr3 = {1,5,4,11, 18,20};
        sort3(arr3);
        print(arr3);
        System.out.println();

        int[] arr4 = {1,5,4,11, 18,20};
        sort4(arr4);
        print(arr4);
        System.out.println();

    }

}

複製程式碼

第一種排序和第二種排序執行的次數是一樣的.

第三種和第四種是基於第二種進行的改進.

第三種排序進行了是否移位的判斷,如果一次內迴圈過後,沒有進行交換,則代表陣列的順序已經是排序完成的.

第四種排序每次內迴圈的時候記錄最後一次交換的位置,然後下次迴圈的時候只迴圈到上次交換的位置.(因為最後一次交換的位置之後的順序都是正常排序後的)

相關文章