每日一題:算法排序 (冒泡排序 算法優化實現)

package com.hangzhou.springcloud.service.impl;

import com.alibaba.fastjson.JSON;

/**
 * 冒泡排序  時間複雜度爲O(n平方)  平方階
 * <p>
 * {2,5,1,3,7,4}
 * 第一步:{2,1,3,5,4,7} 找出末位最大值7
 * 第二步:{1,2,3,4,5,7} 找出倒數第二位最大值5
 * 第三步:{1,2,3,4,5,7} 找出倒數第三位最大值4
 * 第四步:{1,2,3,4,5,7} 找出倒數第四位最大值3
 * 第五步:{1,2,3,4,5,7} 找出倒數第五位最大值2
 * <p>
 * <p>
 * 代碼優化思路:
 * 設置一個標識位,如果走for循環中的賦值替換,則設置boolean爲true ,如果不走判斷,說明在一次排序中一次沒有發生排序交換
 */
public class BubbleSort {

    public static void main(String[] args) {
        int[] arr = {2, 5, 1, 3, 7, 4};

        int[] arr01 = {2, 5, -1, 3, -8, 8, 20, -9, 10, 30, 50, 29};
        //標識
        int temp = 0;
        //默認不走第二層循環 if 判斷
        boolean flag = false;
        for (int i = 0; i < arr01.length - 1; i++) {
            for (int j = 0; j < arr01.length - 1 - i; j++) {
                if (arr01[j] > arr01[j + 1]) {
                    flag = true;
                    //前面一個數的標識值
                    temp = arr01[j];
                    //把後面的數值賦值給前面
                    arr01[j] = arr01[j + 1];
                    //後面的值=前面的標識值
                    arr01[j + 1] = temp;
                }
            }
            if (!flag) {
                break;
            } else {
                flag = false;
            }
            System.out.println("第" + i + "次排序:" + JSON.toJSON(arr01));


        }

    }
}

 

優化前:

第0次排序:[2,-1,3,-8,5,8,-9,10,20,30,29,50]
第1次排序:[-1,2,-8,3,5,-9,8,10,20,29,30,50]
第2次排序:[-1,-8,2,3,-9,5,8,10,20,29,30,50]
第3次排序:[-8,-1,2,-9,3,5,8,10,20,29,30,50]
第4次排序:[-8,-1,-9,2,3,5,8,10,20,29,30,50]
第5次排序:[-8,-9,-1,2,3,5,8,10,20,29,30,50]
第6次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]
第7次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]
第8次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]
第9次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]
第10次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]

優化後:

第0次排序:[2,-1,3,-8,5,8,-9,10,20,30,29,50]
第1次排序:[-1,2,-8,3,5,-9,8,10,20,29,30,50]
第2次排序:[-1,-8,2,3,-9,5,8,10,20,29,30,50]
第3次排序:[-8,-1,2,-9,3,5,8,10,20,29,30,50]
第4次排序:[-8,-1,-9,2,3,5,8,10,20,29,30,50]
第5次排序:[-8,-9,-1,2,3,5,8,10,20,29,30,50]
第6次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]
第7次排序:[-9,-8,-1,2,3,5,8,10,20,29,30,50]

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