算法 -- 冒泡排序

一、定义

通过相邻元素的比较与交换,将较大的元素逐步「冒泡」到数组末尾,较小的元素自然「下沉」到数组开头。

二、算法步骤

步骤1:比较相邻元素

从数组的第一个元素开始,比较当前元素和下一个元素。

步骤2:交换元素

如果当前元素大于下一个元素(升序排序),交换它们的位置。

步骤3:移动指针

向后移动一个位置,继续比较下一对相邻元素。

步骤4:完成一轮

重复步骤1-3,直到达到数组末尾。此时最大的元素已经在正确位置。

步骤5:重复

对剩下的未排序元素重复上述过程,直到整个数组有序。

三、代码实现

复制代码
public class BubbleSort {
    public static void main(String[] args) {
        int[] arr = {64, 34, 25, 12, 22, 11, 90};
        
        System.out.println("排序前: " + Arrays.toString(arr));
        bubbleSort(arr);
        System.out.println("排序后: " + Arrays.toString(arr));
    }
    
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        
        // 外层循环控制轮数
        for (int i = 0; i < n - 1; i++) {
            // 内层循环进行相邻元素比较和交换
            for (int j = 0; j < n - 1 - i; j++) {
                // 如果前一个元素大于后一个元素,交换它们
                if (arr[j] > arr[j + 1]) {
                    // 交换元素
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
            
            // 打印每轮排序结果
            System.out.println("第" + (i + 1) + "轮: " + Arrays.toString(arr));
        }
    }
}

四、算法分析

指标 复杂度 说明
最佳时间复杂度 O(n) 数组已有序,只需一趟遍历
最坏时间复杂度 O(n2) 数组逆序,需要 n 趟遍历
平均时间复杂度 O(n2) 一般情况下的复杂度
空间复杂度 O(1) 原地排序,只使用常数空间
稳定性 稳定 相等元素相对位置不变

五、算法特点

优点:

  1. 简单易懂:逻辑清晰,容易实现

  2. 稳定排序:相等元素的相对位置不变

  3. 原地排序:不需要额外空间

  4. 适应性:对已部分有序的数组效率高

缺点:

  1. 效率低:O(n²)的时间复杂度

  2. 不适合大数据:数据量大时性能差

  3. 多次交换:每轮可能需要多次交换操作

相关推荐
IronMurphy5 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬5 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership6 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826526 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa6 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!6 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
Beginner x_u7 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
丑八怪大丑7 小时前
Java数据结构与集合源码
数据结构
_深海凉_10 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
旖-旎10 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历