当前位置: 首页 > article >正文

【基础1】冒泡排序

核心思想

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

特点:

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

优点

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

缺点

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

适用场景

  • 小规模数据排序(n ≤ 1000)
  • 数据基本有序的情况
  • 日常基本很少使用
代码实现(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]


http://www.kler.cn/a/575863.html

相关文章:

  • 微信小程序注册组件
  • GaussDB安全配置指南:从认证到防御的全方面防护
  • Centos操作系统大全(附ISO镜像下载)
  • 【附源码】Java动漫视频网站源码【带弹幕系统】+SpringBoot+VUE+前后端分离
  • 遵义市招生管理信息系统的开发与实现
  • CentOS7安装Mysql5.7(ARM64架构)
  • 基于SNR估计的自适应码率LDPC编译码算法matlab性能仿真,对比固定码率LDPC的系统传输性能
  • windows:curl: (60) schannel: SEC_E_UNTRUSTED_ROOT (0x80090325)
  • 使用Galaxy创建生物信息学工作流的步骤详解
  • 可视化大屏出圈密码:地图组件深度解析
  • 淘宝关键字搜索接口爬虫测试实战指南
  • TypeError: Cannot create property ‘xxx‘ on string ‘xxx‘
  • STM32 子设备通过CAN发送数据到主设备
  • 【游戏】【客户端性能测试】
  • QILSTE灯珠:尺寸光电全解析
  • 1688平台API接口实战:Python实现店铺全量商品数据抓取
  • 工程化与框架系列(22)--前端性能优化(中)
  • OpenHarmony子系统开发编译构建指导
  • 大数据学习(57)-DataX基础
  • 开发vue小游戏:数字华龙道