美文网首页
排序之一:冒泡排序

排序之一:冒泡排序

作者: 筱南独舞 | 来源:发表于2016-07-29 14:36 被阅读110次
  • **介绍 **
    冒泡排序法又称为交换排序,其比较方式由第一个元素开始,比较相邻元素大小,若大小顺序有误,则对调后再进行下一个元素的比较。如此扫描过一次后就可确保最后一个元素是位于正确的顺序。接着再进行第二次扫描,直到完成所有元素的排序关系为之。
  • 演示
    代码如下:
    private static void bubbleSort() {
        int data[] = {9, 6, 3, 2, 4, 5, 1, 8, 7};
        int i, j, tmp;
        for (i = data.length - 1; i > 0; i--) {
            for (j = 0; j < i; j++) {
                if (data[j] > data[j + 1]) {
                    tmp = data[j];
                    data[j] = data[j + 1];
                    data[j + 1] = tmp;
                }
            }
        }
    }

打印结果:


冒泡排序打印信息.png
  • 分析
    1. 最坏情况及平均情况均需比较n(n-1)/2次;时间复杂度为O(n²),最好情况只需要完成一次扫描,发现没有做交换的操作则表示排序已经完成,所以只做了n-1次比较,是复杂度为O(n)。
    2. 由于冒泡排序为相邻两者相互比较对调,并不会更变其原本排序的顺序,所以是稳定排序法。
    3. 只需一个额外的空间,所以空间复杂度为最佳。
    4. 冒泡排序法适用于数据量小或者有部分数据已经排序过的情况。
  • 优化
    通过上边的演示可以看出冒泡排序法有一个缺点,就是不管数据是否已经排序完成都会固定执行n(n-1)/2次,所以需要在排序中增加标记来提前中断程序,以此提高执行效率,代码如下:
    private static void bubbleSort() {
        int data[] = {9, 6, 3, 2, 4, 5, 1, 8, 7};
        int i, j, tmp, flag;
        for (i = data.length - 1; i > 0; i--) {
            flag = 0;    // flag 用来判断是否有执行
            for (j = 0; j < i; j++) {
                if (data[j] > data[j + 1]) {
                    tmp = data[j];
                    data[j] = data[j + 1];
                    data[j + 1] = tmp;
                    flag++;    // 如果有执行过交换,则flag不为0
                }
            }
            if (flag == 0){
                break;    // 如果没有发生过交换就退出
            }
        }
    }
  • 后记
    通过比较会发现一个有意思的现象,冒泡排序每次扫描都会确定后边的元素为目标顺序,而选择排序每次都扫描都会确定前边的元素为目标顺序。

其他排序:插入排序选择排序希尔排序快速排序基数排序

相关文章

  • Java语言——数组排序算法

    数组有很多常用的算法,包括冒泡排序、直接选择排序和反转排序。 一、冒泡排序 冒泡排序是最常用的数组排序算法之一,它...

  • 前端算法学习-第一篇

    冒泡排序算法 冒泡排序算法是最慢的排序算法之一,也是最容易实现的排序算法。之所以叫冒泡排序是因为使用这种算法排序时...

  • 前端常见的排序算法算法

    冒泡排序 我们先来了解一下冒泡排序算法,它是最慢的排序算法之一,但也是一种最容易实现的排序算法。之所以叫冒泡排序是...

  • 浅谈冒泡排序

    一、冒泡排序 冒泡排序是我们所掌握的最基础的排序算法之一,它的排序思想如下:假设我们的排序要求为:数组大小为N的,...

  • 算法-冒泡排序

    算 法:冒泡排序算法时间复杂度: 冒泡排序算法概述 冒泡排序伪代码 冒泡排序实现 冒泡排序算法概述 冒泡排...

  • 02《算法入门教程》冒泡排序

    1. 前言 本节内容是排序算法系列之一:冒泡排序,主要讲解了冒泡排序的主体思路,选取了一个待排序的数字列表对冒泡排...

  • 笔记||冒泡排序

    冒泡排序是最出名的排序算法之一,总共有八大排序 所谓冒泡排序也就是,两层循环,外层表示冒泡轮数,里面依次比较。pa...

  • 排序算法

    排序算法 排序是最基本的算法之一,常见的排序算法有插入排序、希尔排序、选择排序、冒泡排序、堆排序、归并排序及快速排...

  • 排序算法

    排序算法 冒泡排序 选择排序 直接插入排序 希尔排序 堆排序 归并排序 快速排序 冒泡排序 冒泡排序是一种交换排序...

  • dailyLearning -- 排序算法

    目录: 冒泡排序 快速排序 选择排序 插入排序 归并排序 冒泡排序 冒泡排序(Bubble Sort),是一种计算...

网友评论

      本文标题:排序之一:冒泡排序

      本文链接:https://www.haomeiwen.com/subject/sihzjttx.html