Java 冒泡和插入排序鍛鍊

    // 冒泡排序,a 表示數組,n 表示數組大小
    public void bubbleSort(int[] a, int n) {
        if (n <= 1) return;
        for (int i = 0; i < n; ++i) {
            // 提前退出冒泡循環的標誌位
            boolean flag = false;
            for (int j = 0; j < n - i - 1; ++j) {
                if (a[j] > a[j+1]) { // 交換
                    int tmp = a[j];
                    a[j] = a[j+1];
                    a[j+1] = tmp;
                    flag = true;  // 表示有數據交換
                }
            }
            if (!flag) break;  // 沒有數據交換,提前退出
        }
        System.out.println(Arrays.toString(a));
    }
    // 插入排序,a 表示數組,n 表示數組大小
    public void insertionSort(int[] a, int n) {
        if (n <= 1) return;

        for (int i = 1; i < n; ++i) {
            int value = a[i];
            int j = i - 1;
            // 查找插入的位置
            for (; j >= 0; --j) {
                if (a[j] > value) {
                    a[j+1] = a[j];  // 數據移動
                } else {
                    break;
                }
            }
            a[j+1] = value; // 插入數據
        }
        System.out.println(Arrays.toString(a));
    }

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章