`

交换排序之冒泡排序Bubble Sort

阅读更多

 

 概述

   Bubble Sort冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

 

算法描述

  • 比较相邻的元素。如果第一个比第二个大,就交换它们两个;
  • 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对,这样在最后的元素应该会是最大的数;
  • 针对所有的元素重复以上的步骤,除了最后一个;
  • 重复步骤1~3,直到排序完成。

动图


 

代码实现

第一种实现:

    原始的冒泡排序算法,性能差

/**
     * 冒泡排序的第一种实现, 没有任何优化
     *
     * @param source
     */
    public static void bubbleSort1(Integer[] source) {
        int i, j;
        int size = source.length;

        for (i = 0; i < size; i++) {//表示n次排序过程。
            for (j = 1; j < size - i; j++) {//i以后的都已经有序,不需要再排序
                if (source[j - 1] > source[j]) {//前面的数字大于后面的数字就交换
                    //交换a[j-1]和a[j]
                    int temp;
                    temp = source[j - 1];
                    source[j - 1] = source[j];
                    source[j] = temp;
                }
            }
        }
        print(source);
    }// end

 第二种实现:

  

/**
     * 冒泡排序的第二种实现, 当前一次排序没有调整顺序,说明已有序
     *
     * @param source
     */
    public static void bubbleSort2(Integer[] source) {
        int i, j;
        int size = source.length;
        boolean flag = false;//表示是否有调整顺序

        for (i = 0; i < size; i++) {//表示n次排序过程。
            flag = false;
            for (j = 1; j < size - i; j++) {//i以后的都已经有序,不需要再排序
                if (source[j - 1] > source[j]) {//前面的数字大于后面的数字就交换
                    flag = true;
                    //交换a[j-1]和a[j]
                    int temp;
                    temp = source[j - 1];
                    source[j - 1] = source[j];
                    source[j] = temp;
                }
            }
            if (!flag) {
                break;
            }
        }
        print(source);
    }// end

 第三种实现:

 

 /**
     * 冒泡排序的第三种实现, 针对序列后半部分基本有序的情况,可减少循环次数
     *
     * @param source
     */
    public static void bubbleSort3(Integer[] source) {
        int j, k;
        int flag = source.length;//记录最后交换的位置,也就是排序的尾边界

        while (flag > 0) {//排序未结束标志
            k = flag; //k 来记录遍历的尾边界
            flag = 0;

            for (j = 1; j < k; j++) {
                if (source[j - 1] > source[j]) {//前面的数字大于后面的数字就交换
                    //交换a[j-1]和a[j]
                    int temp;
                    temp = source[j - 1];
                    source[j - 1] = source[j];
                    source[j] = temp;

                    //表示交换过数据;
                    flag = j;//记录最新的尾边界.
                }
            }
        }

        print(source);
    }// end

 

测试:

public static void main(String[] args) {
        Integer[] data = {2, 5, 8, 10, 9, 22, 34, 7, 13, 16, 9};

        print(data);
        bubbleSort1(data);

        Integer[] data2 = {2, 5, 8, 10, 9, 22, 34, 7, 13, 16, 9};
        print(data2);
        bubbleSort2(data2);

        //后面已有序
        Integer[] data3 = {2, 5, 8, 10, 9, 22, 34, 7, 13, 16, 9, 36, 40, 43, 50};
        print(data3);
        bubbleSort3(data3);
    }

 

算法复杂度

  • 时间复杂度 

   最好的情况, 即要排序的数据本身就是有序的,那么比较次数,根据最后改进的代码,可以推断出就是n-1次的比较,没有数据交换,时间复杂度为O(n)。当最坏的情况,即待排序表是逆序的况,此时需要比较n(n+1)/2次,并作等数量级的记录移动。因此,总的时间复杂度为O(n^2)。

  • 空间复杂度

    由以上算法步骤分析,可轻易得知冒泡排序的空间复杂度为 O(n), 需要辅助空间 O(1)

 

算法稳定性

   在相邻元素相等时,并不需要交换它们的位置,所以,冒泡排序是稳定排序。

 

算法适用场景

  在算法优化中提到过,实际使用过程中,在大量数据的情况下几乎不适用冒泡排序。

冒泡排序思路简单,代码简单,特别适合小数据的排序。

但是,由于算法复杂度较高,在数据量大的时候不适合使用。

 

参考:

   https://www.cnblogs.com/onepixel/p/7674659.html

 

  • 大小: 455.9 KB
分享到:
评论

相关推荐

    冒泡排序(Bubble Sort)

    冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。 它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从A到Z)错误就把他们交换过来。走访元素的工作是...

    经典排序算法,有选择排序,冒泡排序,交换排序,谢尔排序,插入排序基数排序

    根据给定的文件信息,我们将深入探讨几种经典的排序算法,包括选择排序、冒泡排序、交换排序、希尔排序、插入排序以及基数排序。这些算法在计算机科学领域内有着广泛的应用,各自具有独特的特点和适用场景。 ### 1....

    冒泡排序(Bubble Sort)是一种基本的比较排序算法 冒泡法排序c语言程序

    冒泡排序(Bubble Sort)是一种基本的比较排序算法,它的工作原理非常简单,但效率相对较低。冒泡排序的核心思想是多次遍历待排序的元素,比较相邻的两个元素,并将较大的元素向后交换,这样较大的元素会像气泡一样...

    基于python的排序算法-冒泡排序Bubble Sort

    冒泡排序(Bubble Sort)是一种简单的排序算法,其工作原理是通过重复地遍历待排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列...

    冒泡排序(Bubble Sort)是一种简单的排序算法

    冒泡排序(Bubble Sort)是一种简单的排序算法。它通过重复遍历待排序的数列,依次比较相邻的元素,如果顺序错误就交换它们,直到整个数列有序。 冒泡排序的基本步骤: 从头到尾遍历数列,比较相邻的元素。 如果前一...

    交换排序\冒泡排序.

    冒泡排序(Bubble Sort)是一种基础的排序算法,它的核心思想是通过重复遍历待排序的元素列表,比较相邻元素并根据需要交换它们的位置,使得每次遍历时最大(或最小)的元素“浮”到列表的一端。这个过程就像水中的...

    TIA博途SCL语言冒泡排序算法FC全局库文件(可选升序降序)GF-bubble-Sort.zip

    冒泡排序是一种简单但效率较低的排序算法,它的基本思想是通过重复遍历待排序的序列,比较相邻元素并根据需要交换它们的位置,直到序列中所有元素都按照指定顺序排列。这个过程就像水底下的气泡逐渐上升到水面一样,...

    python冒泡排序(Bubble Sort).docx

    冒泡排序(Bubble Sort)是一种基础且直观的排序算法,其基本思想是通过不断地交换相邻的未按正确位置排列的元素来对数据序列进行排序。这个过程可以形象地理解为较轻的元素会像气泡一样逐渐“浮”到序列的顶端,故...

    C 语言实现的冒泡排序(Bubble Sort)

    冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地遍历待排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。...

    c语言实现冒泡排序(Bubble Sort)

    冒泡排序(Bubble Sort)是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成

    java基础冒泡排序.ppt

    冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。 它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。 走访元素的工作是重复...

    合并排序,插入排序,希尔排序,快速排序,冒泡排序,桶排序的C语言实现

    5. **冒泡排序(Bubble Sort)**: 冒泡排序是最基础的排序算法,通过不断交换相邻的逆序元素,使得较大的元素逐渐“浮”到数组的高端。尽管效率较低,时间复杂度为O(n^2),但它易于理解和实现。 6. **桶排序...

    通过C语言实现冒泡排序(Bubble Sort).zip

    冒泡排序(Bubble Sort)是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复进行的,直到没有再需要交换的元素为止,这意味着该数列...

    通过python实现冒泡排序(bubble-sort).rar

    冒泡排序(Bubble Sort)是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复进行的,直到没有再需要交换的元素为止,这时数列就完全...

    排序:插入排序,选择排序,基数排序,冒泡排序

    冒泡排序是最简单的排序算法之一,它通过重复遍历待排序的列表,比较相邻元素并交换位置,直到没有任何一对数字需要比较。C++实现冒泡排序如下: ```cpp void bubbleSort(int arr[], int n) { for (int i = 0; i ;...

    选择排序,插入排序,冒泡排序

    最后,我们来讨论**冒泡排序**(Bubble Sort)。该算法通过重复遍历列表,比较相邻的元素并根据需要交换它们,使得较大的元素逐渐“浮”到列表的顶部,就像水中的气泡上升一样。冒泡排序的时间复杂度同样为O(n^2),...

    交换排序实现源码

    本文将深入探讨两种交换排序算法——冒泡排序和快速排序的实现原理及源码分析。 **冒泡排序(Bubble Sort)** 冒泡排序是一种简单直观的排序算法,它重复地遍历待排序的列表,一次比较两个元素,如果他们的顺序...

    经典排序算法之冒泡排序(Bubble sort)代码

    经典排序算法 – 冒泡排序Bubble sort 原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换, 这样一趟过去后,最大或最小的数字被交换到了最后一位, 然后再从头开始进行两两比较交换,直到倒数第二...

Global site tag (gtag.js) - Google Analytics