我叫:冒泡排序【JAVA】

1.什么是冒泡排序?

冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就象水底下的气泡一样逐渐向上冒。

2.来个实战应用

我们举一个具体的案例来说明冒泡法。我们将五个无序的数:3,9,-1,10,20使用冒泡排序法将其排成一个从小到大的有序数列。

3.实战总结

  • 一共进行数组的大小-1次大的循环

  • 每一趟排序的次数在逐渐的减少

  • 每一排序的次数住逐新的减少如果我们发现在某趟排序中,没有发生一次交换,可以提前结束冒泡排序。

4.代码助力

java 复制代码
 int[] array = new int[]{3, 9, -1, 10, 2};

        for (int i = 0; i < array.length - 1; i++) {
            for (int j = 0; j < array.length - i - 1; j++) {
                if (array[j] > array[j + 1]) {
                    int temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
                }
            }
                System.out.println("第"+(i+1)+"趟排序后的顺序:"+Arrays.toString(array));
        }
        System.out.println("从小到大的排序:"+Arrays.toString(array));
    }

5.优化一下我

  • 每一排序的次数住逐新的减少如果我们发现在某趟排序中,没有发生一次交换,可以提前结束冒泡排序。
java 复制代码
        boolean flag = false;//标识变量
        for (int i = 0; i < array.length - 1; i++) {
            for (int j = 0; j < array.length - i - 1; j++) {
                if (array[j] > array[j + 1]) {
                    flag = true;
                    int temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
                }
            }
            System.out.println("第" + (i + 1) + "趟排序后的顺序:" + Arrays.toString(array));
            if (!flag) {//在一趟排序中,没有发生一次交换
                break;
            } else {
                flag = false;//重置
            }
        }
        System.out.println("从小到大的排序:" + Arrays.toString(array));
    }

相关推荐
earthzhang20215 分钟前
第3讲:Go垃圾回收机制与性能优化
开发语言·jvm·数据结构·后端·性能优化·golang
apocelipes35 分钟前
golang unique包和字符串内部化
java·python·性能优化·golang
Full Stack Developme1 小时前
java.text 包详解
java·开发语言·python
刘梦凡呀2 小时前
C#获取钉钉平台考勤记录
java·c#·钉钉
丁浩6662 小时前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
thinktik2 小时前
AWS EKS 集成Load Balancer Controller 对外暴露互联网可访问API [AWS 中国宁夏区]
后端·kubernetes·aws
best_virtuoso2 小时前
PostgreSQL 常见数组操作函数语法、功能
java·数据结构·postgresql
yudiandian20142 小时前
02 Oracle JDK 下载及配置(解压缩版)
java·开发语言
追逐时光者3 小时前
将 EasySQLite 解决方案文件格式从 .sln 升级为更简洁的 .slnx
后端·.net
伏小白白白3 小时前
【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
人工智能·算法·机器学习