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]