冒泡排序之Java实现
一、方法一
1 package cn.com.zfc.lesson21.sort; 2 3 import java.util.Arrays; 4 5 /** 6 * 7 * @title BubbleSort 8 * @describe 冒泡排序 9 * @author 张富昌 10 * @date 2016年10月1日下午3:56:30 11 */ 12 public class BubbleSortHigh { 13 // 起泡排序是快速排序的基础,但是排序速度较慢。 14 // 基本思想:将序列中第 1 个元素与第 2 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 15 // 再将第 2 个元素与第 3 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 16 // 依此类推,直到第 n-1 个元素与第 n 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 17 // 经过如此一趟排序,使得 n 个元素的最大值被安置在第 n 个位置上; 18 // 此后,再对前 n-1 个元素进行同样的过程,使得该 n-1 个元素的最大值被安置在第 n-1 个位置上; 19 // 然后再对前 n-2 个元素重复以上的过程... 直到某一趟排序过程中不出现元素交换位置的动作,排序结束。 20 21 public static void main(String[] args) { 22 // 声明整型数组 23 int[] array = new int[10]; 24 // 使用循环和随机数初始化数组 25 for (int i = 0; i < array.length; i++) { 26 array[i] = (int) Math.round(Math.random() * 100); 27 } 28 System.out.println("原始数组为:"); 29 System.out.println(Arrays.toString(array)); 30 System.out.println("--------------------------------------"); 31 32 array = bubbleSort(array); 33 System.out.println("--------------------------------------"); 34 System.out.println("排序后的数组为:"); 35 System.out.println(Arrays.toString(array)); 36 } 37 38 /** 39 * 40 * 功能:冒泡排序的基本思想就是不断比较相邻的两个数,让较大的元素不断地往后移。经过一轮比较,就选出最大的数;经过第2轮比较,就选出次大的数, 41 * 以此类推。 42 * 43 * 44 * 参数:int[] array 45 * 46 * 返回类型:int[] 47 */ 48 private static int[] bubbleSort(int[] array) { 49 // 使用临时数组,替代原始数组 50 int[] arr = array; 51 for (int i = 0; i < arr.length; i++) { 52 System.out.println("第 " + (i + 1) + "趟"); 53 // 交换的标志,初始值为 false 54 boolean swap = false; 55 56 for (int j = 0; j < arr.length - 1 - i; j++) { 57 if (arr[j] > arr[j + 1]) { 58 // 如果交换了,交换标志置为 true 59 swap = true; 60 int temp = arr[j]; 61 arr[j] = arr[j + 1]; 62 arr[j + 1] = temp; 63 } 64 } 65 System.out.println(Arrays.toString(arr)); 66 // 如果交换标志为 false,即没有交换,则跳出最近的循环 67 if (!swap) { 68 break; 69 } 70 } 71 return arr; 72 } 73 74 }
运行结果:
二、方法二
1 package cn.com.zfc.lesson21.sort; 2 3 import java.util.Arrays; 4 5 /** 6 * 7 * @title BubbleSort 8 * @describe 冒泡排序 9 * @author 张富昌 10 * @date 2016年10月1日下午3:56:30 11 */ 12 public class BubbleSortLow { 13 // 起泡排序是快速排序的基础,但是排序速度较慢。 14 // 基本思想:将序列中第 1 个元素与第 2 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 15 // 再将第 2 个元素与第 3 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 16 // 依此类推,直到第 n-1 个元素与第 n 个元素进行比较,如前者大于后者,则两个元素交换位置,否则不交换; 17 // 经过如此一趟排序,使得 n 个元素的最大值被安置在第 n 个位置上; 18 // 此后,再对前 n-1 个元素进行同样的过程,使得该 n-1 个元素的最大值被安置在第 n-1 个位置上; 19 // 然后再对前 n-2 个元素重复以上的过程... 直到某一趟排序过程中不出现元素交换位置的动作,排序结束。 20 21 public static void main(String[] args) { 22 // 声明整型数组 23 int[] array = new int[10]; 24 // 使用循环和随机数初始化数组 25 for (int i = 0; i < array.length; i++) { 26 array[i] = (int) Math.round(Math.random() * 100); 27 } 28 System.out.println("原始数组为:"); 29 System.out.println("--------------------------------------"); 30 System.out.println(Arrays.toString(array)); 31 array = bubbleSort(array); 32 System.out.println("--------------------------------------"); 33 System.out.println("排序后的数组为:"); 34 System.out.println(Arrays.toString(array)); 35 } 36 37 /** 38 * 39 * 功能:冒泡排序的基本思想就是不断比较相邻的两个数,让较大的元素不断地往后移。经过一轮比较,就选出最大的数;经过第2轮比较,就选出次大的数, 40 * 以此类推。 41 * 42 * 43 * 参数:int[] array 44 * 45 * 返回类型:int[] 46 */ 47 private static int[] bubbleSort(int[] array) { 48 // 使用临时数组,替代原始数组 49 int[] arr = array; 50 for (int i = 0; i < arr.length; i++) { 51 System.out.println("第 " + (i + 1) + "趟"); 52 for (int j = 0; j < arr.length - 1 - i; j++) { 53 if (arr[j] > arr[j + 1]) { 54 int temp = arr[j]; 55 arr[j] = arr[j + 1]; 56 arr[j + 1] = temp; 57 } 58 } 59 // 打印每一趟的数组 60 System.out.println(Arrays.toString(arr)); 61 } 62 return arr; 63 } 64 65 }
运行结果: