算法 -- 冒泡排序

一、定义

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

二、算法步骤

步骤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. 多次交换:每轮可能需要多次交换操作

相关推荐
寻星探路2 小时前
【算法专题】滑动窗口:从“无重复字符”到“字母异位词”的深度剖析
java·开发语言·c++·人工智能·python·算法·ai
wen__xvn2 小时前
代码随想录算法训练营DAY14第六章 二叉树 part02
数据结构·算法·leetcode
Ka1Yan3 小时前
[数组] - 代码随想录(2-6)
数据结构·算法·leetcode
漫随流水3 小时前
leetcode算法(104.二叉树的最大深度)
数据结构·算法·leetcode·二叉树
机器学习之心HML4 小时前
鲸鱼算法(WOA)优化Kriging模型
算法
DYS_房东的猫4 小时前
《 C++ 零基础入门教程》第6章:模板与 STL 算法 —— 写一次,用万次
开发语言·c++·算法
Tim_104 小时前
【算法专题训练】37、前缀树&二叉树
算法
NineData4 小时前
第三届数据库编程大赛-八强决赛成绩揭晓
数据库·算法·代码规范
雍凉明月夜4 小时前
深度学习之目标检测yolo算法Ⅱ(v4)
深度学习·算法·yolo·目标检测