Java数组——冒泡排序

冒泡排序是最出名排序算法 之一,总共有八大排序

冒泡排序代码并不复杂,共两层循环,外层冒泡轮数,里层依次比较


算法步骤:

  1. 比较数组中两个相邻元素,如果第一个元素比第二个元素大,交换位置

  2. 每一次比较,都会产生一个最大,或者最小的数字;

  3. 下一轮可以少一次排序

  4. 依次循环,直到结束


代码演示:

java 复制代码
    public static void main(String[] args) {
        int[] a = {1,5,6,98,52,66,91,2};
        int[] sort = sort(a);
        System.out.println(Arrays.toString(sort));  //[98, 91, 66, 52, 6, 5, 2, 1]
    }

    //冒泡排序

    public static int[] sort(int[] array){
        //临时变量
        int c = 0;
        //外层循环,判断我们循环要走多少次
        for (int i = 0; i < array.length-1; i++) {  //-1是为了不让溢出
            //内层循环,比较两个数
            for (int j = 0; j < array.length-1-i; j++) {
                if (array[j+1]>array[j]){
                    c = array[j];
                    array[j] = array[j+1];
                    array[j+1] = c;
                }
            }
        }
        return array;
    }

当然,我们还能进一步优化一下:

java 复制代码
    public static int[] sort(int[] array){
        //临时变量
        int c = 0;
        //外层循环,判断我们循环要走多少次
        for (int i = 0; i < array.length-1; i++) {  //-1是为了不让溢出

            boolean flag = false;  //通过flag标志位减少无意义比较

            //内层循环,比较两个数
            for (int j = 0; j < array.length-1-i; j++) {
                if (array[j+1]>array[j]){
                    c = array[j];
                    array[j] = array[j+1];
                    array[j+1] = c;
                    flag = true;
                }
            }
            if (flag == false){
                break;
            }
        }
        return array;
    }
相关推荐
呼啦啦啦啦啦啦啦啦12 分钟前
【Redis】持久化机制
java·redis·mybatis
Evand J21 分钟前
matlab绘图——彩色螺旋图
开发语言·matlab·信息可视化
我想学LINUX1 小时前
【2024年华为OD机试】 (A卷,100分)- 微服务的集成测试(JavaScript&Java & Python&C/C++)
java·c语言·javascript·python·华为od·微服务·集成测试
深度混淆1 小时前
C#,入门教程(04)——Visual Studio 2022 数据编程实例:随机数与组合
开发语言·c#
雁于飞1 小时前
c语言贪吃蛇(极简版,基本能玩)
c语言·开发语言·笔记·学习·其他·课程设计·大作业
wenxin-2 小时前
NS3网络模拟器中如何利用Gnuplot工具像MATLAB一样绘制各类图形?
开发语言·matlab·画图·ns3·lr-wpan
数据小爬虫@4 小时前
深入解析:使用 Python 爬虫获取苏宁商品详情
开发语言·爬虫·python
健胃消食片片片片4 小时前
Python爬虫技术:高效数据收集与深度挖掘
开发语言·爬虫·python
王老师青少年编程5 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
空の鱼6 小时前
java开发,IDEA转战VSCODE配置(mac)
java·vscode