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

    运行结果:

  • 相关阅读:
    随机过程之第一次出现的期望
    js模板引擎介绍搜集
    qt的安装和debug
    $parse/$eval和$observe/$watch如何区分
    angular controller as syntax vs scope
    Angularjs Controller 间通信机制
    Ng-template寄宿方式
    angularjs移除不必要的$watch
    angularJs项目实战!02:前端的页面分解与组装
    推荐几个可以与PhoneGap很好搭配的UI框架
  • 原文地址:https://www.cnblogs.com/zfc-java/p/7940976.html
Copyright © 2020-2023  润新知