package com.bigdata.datastructure.sort;
import java.util.Arrays;
/**
* 冒泡排序原理:(升序)
* 一轮比较中,先从头至尾比较相邻两个数.将新得到的顺序的第二个数和下一个数进行比较,以此类推,直到一轮比较完成;
* 一轮比较完成时,将最大值沉到最后
* @ description: 冒泡排序(优化)
* @ author: spencer
* @ date: 2020/11/4 14:51
*/
public class BubbleSort {
public static void main(String[] args) {
int[] arr = {3, 9, -1, 10, 20};
bubbleSort(arr);
/* // 冒泡排序的演化:
// 第一趟排序,将最大的数放到最后一位
int temp = 0;
for (int j = 0; j < arr.length - 1; j++) {
if (arr[j] > arr[j + 1]){
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
System.out.println("第一趟排序的结果是:" + Arrays.toString(arr));
// 第二趟排序,将最大的数放到倒数第二位
for (int j = 0; j < arr.length - 1 - 1; j++) {
if (arr[j] > arr[j + 1]){
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
System.out.println("第二趟排序的结果是:" + Arrays.toString(arr));
// 第三趟排序,将最大的数放到倒数第三位
for (int j = 0; j < arr.length - 1 - 2; j++) {
if (arr[j] > arr[j + 1]){
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
System.out.println("第三趟排序的结果是:" + Arrays.toString(arr));
// 第四趟排序,将最大的数放到倒数第四位
for (int j = 0; j < arr.length - 1 - 3; j++) {
if (arr[j] > arr[j + 1]){
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
System.out.println("第四趟排序的结果是:" + Arrays.toString(arr));*/
}
/**
* 将优化后的冒泡排序封装成方法
* @param arr
*/
public static void bubbleSort(int[] arr) {
// 演化中的四趟刚好又可以使用一个循环进行控制
// 只需要执行的趟数:arr.length - 1趟
int temp = 0;
// flag:标识变量,标识是否进行过交换
boolean flag = false;
for (int i = 0; i < arr.length - 1; i++) {
for (int j = 0; j < arr.length - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
flag = true;
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
System.out.println("第" + (i + 1) + "趟排序的结果是:" + Arrays.toString(arr));
if (!flag) { // 如果当前趟数循环完成都没有进行过交换,则直接返回
break;
} else {
flag = false; // 重置flag,进行下次判断
}
}
}
}
java实现冒泡排序(推导、优化)
最新推荐文章于 2024-08-15 21:34:12 发布