冒泡排序之Java实现

冒泡排序之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 }

运行结果:

posted @ 2017-12-01 11:05  勇闯天涯zfc  阅读(183)  评论(0编辑  收藏  举报