【基础1】冒泡排序

核心思想

冒泡排序是通过相邻元素的连续比较和交换,使得较大的元素逐渐"浮"到数组的末尾,如同水中气泡上浮的过程

特点:

  • 每轮遍历将最大的未排序元素移动到正确位置
  • 稳定排序:相等元素的相对位置保持不变
  • 原地排序:不需要额外存储空间
复杂度
情况 时间复杂度 空间复杂度
最好情况 O(n) O(1)
最坏情况 O(n²) O(1)
平均情况 O(n²) O(1)
优缺点

优点

  1. 实现简单,代码易读
  2. 不需要额外内存空间
  3. 对部分有序数组效率较高(通过优化)

缺点

  1. 时间复杂度较高,不适合大数据量
  2. 元素需要频繁交换,效率低于其他O(n²)算法(如选择排序)

适用场景

  • 小规模数据排序(n ≤ 1000)
  • 数据基本有序的情况
  • 日常基本很少使用
代码实现(Java)
java 复制代码
public class BubbleSortDemo {
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        //外层循环控制排序轮数
        for (int i = 0; i < n - 1; i++) {
            //内层循环控制相邻元素比较
            for (int j = 0; j < n - i - 1; j++) {
                //升序排列的交换逻辑
                if (arr[j] > arr[j + 1]) {
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
    }

    public static void main(String[] args) {
        int[] data = {5, 3, 8, 4, 2};
        System.out.println("排序前: " + Arrays.toString(data));
        bubbleSort(data);
        System.out.println("排序后: " + Arrays.toString(data));
    }
}
过程示例

初始: 5 3 8 4 2

第1轮:3 5 4 2 [8]

第2轮:3 4 2 [5 8]

第3轮:3 2 [4 5 8]

第4轮:2 [3 4 5 8]

相关推荐
能工智人小辰7 分钟前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
kingmax542120088 分钟前
CCF GESP202503 Grade4-B4263 [GESP202503 四级] 荒地开垦
数据结构·算法
岁忧13 分钟前
LeetCode 高频 SQL 50 题(基础版)之 【高级字符串函数 / 正则表达式 / 子句】· 上
sql·算法·leetcode
pan_junbiao23 分钟前
Spring框架的设计模式
java·spring·设计模式
远方160924 分钟前
0x-2-Oracle Linux 9上安装JDK配置环境变量
java·linux·oracle
北执南念30 分钟前
CompletableFuture+线程池使用案列
java
eachin_z1 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
黄交大彭于晏1 小时前
发送文件脚本源码版本
java·linux·windows
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
钮钴禄·爱因斯晨1 小时前
Java 面向对象进阶之多态:从概念到实践的深度解析
java·开发语言·数据结构