[图解] 冒泡排序

1. 图示过程

2. 动图展示

3. 文字叙述过程

对于一组包含n个数据的记录,冒泡排序在最坏的情况下需要进行n-1趟排序

  • 第1趟:依次比较0和1、1和2、2和3...(n-2)和(n-1)索引的元素,如果发现第1个数据大于第2个数据,交换他们,经过第1趟排序,最大的元素排到了最后
  • 第2趟:依次比较0和1、1和2、2和3...(n-3)和(n-3)索引的元素,如果发现第1个数据大于第2个数据,交换他们,经过第2趟排序,第二大的元素排到了倒数第二个位置
  • ...
  • 第n-1趟:比较0和1索引的元素,如果发现第1个数据大于第2个数据,交换他们,经过第n-1趟排序,第二小的元素排到了第二个位置

4. Java代码实现

public static void bubbleSort(int[] arr) {

    if (arr == null || arr.length < 2) {
        return;
    }

    for(int i = arr.length - 1; i > 0; i--) {
        for(int j = 0; j < i; j++) {
            if(arr[j] > arr[j + 1]) {
                swap(arr, j, j + 1);
            }
        }
    }

}

public static void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}

5. 复杂度

  • 时间复杂度:O(n²)
  • 空间复杂度:O(1),只需要一个额外空间用于交换
  • 稳定性:冒泡排序是稳定的排序算法,因为可以实现值相等的元素的相对位置不变,例如我们上面的代码中,if (arr[j] > arr[j + 1]) { swap(arr, j, j + 1); } ,只有当arr[j] > arr[j + 1]的时候才交换,这时候就是稳定的,假如写成if (arr[j] >= arr[j + 1]) { swap(arr, j, j + 1); },冒泡排序的功能还是可以实现,但是值相等的元素的相对位置发生了改变,此时就是不稳定的。

6. 优化

在上面实现的代码中,即使n个数本来就是有序的,也会进行(n-1)次排序(只比较,不交换)
优化:当某趟没有发生交换,说明数组已经有序,就中断程序

public static void bubbleSort(int[] arr) {
    
    if (nums == null || nums.length < 2) {
        return;
    }
    
    for (int i = arr.length - 1; i > 0; i--) {
        boolean swapped = false;
        for (int j = 0; j < i; j++) {
            if (arr[j] > arr[j + 1]) {
                swap(arr, j, j + 1);
                swapped = true;
            }
        }
        if(!swapped) {
            break;
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 排序的基本概念 在计算机程序开发过程中,经常需要一组数据元素(或记录)按某个关键字进行排序,排序完成的序列可用于快...
    Jack921阅读 1,485评论 1 4
  • 原作者:涛声依旧,微信公众号“趣味编程”原博客链接:图解冒泡排序 冒泡排序是一个比较经典和简单的排序算法,今天我们...
    骇客与画家阅读 1,013评论 0 1
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,753评论 0 15
  • 目录 二十二 七月的天气,夜短昼长,再过一个时辰天就亮了。 楚图南心中也不知那股海贼是否今夜一定来攻。他向东边望望...
    德万托阿阅读 557评论 0 4
  • 很久不写东西了,不是没试过,只是文字枯竭。 天气越来越冷了,街道上的梧桐树叶铺在石板上,一层又一层,像是给这偌大却...
    与风的夏天阅读 388评论 2 0