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

【基础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]

相关文章:

  • ERNIE 3.0: 大规模知识增强的预训练语言理解和生成框架
  • 【Minio】Docker部署Minio + 使用nginx配置https访问
  • 【漫话机器学习系列】124.感知机(Perceptron)
  • vue3中emits
  • 【预测】-双注意LSTM自动编码器记录
  • 职坐标机器学习编程实战:调试优化与自动化测试精要
  • 【C语言】指针篇
  • Python | 机器学习中最常用的超参数及使用示例
  • window系统中的start命令详解
  • SSM架构 +Nginx+FFmpeg实现rtsp流转hls流,在前端html上实现视频播放
  • RSA-OAEP填充方案与定时攻击防护
  • 人工智能之数学基础:对线性代数中逆矩阵的思考?
  • springboot011基于springboot的课程作业管理系统(源码+包运行+LW+技术指导)
  • Android中AIDL和HIDL的区别
  • 智慧校园总体方案
  • React Native国际化实践(react-i18next)
  • Centos的ElasticSearch安装教程
  • 退化环境定位(四):基于强度的感知定位方法
  • 云计算VS网络安全,应该怎么选?
  • hooks useModule自定义hooks (二次封装AgGridReact ag-table)自定义表头,自定义表头搜索
  • 医疗软件网站建设公司/站长之家seo综合
  • 怎么样可以建设网站/自己做网站需要什么条件
  • 个人网站的制作代码/百度资源搜索资源平台
  • 北碚集团网站建设/seo诊断的网络问题
  • wordpress加漂浮广告/百度关键词自然排名优化公司
  • 企业网站改版新闻/站长之家官网登录入口