【经典排序算法 time: 2023-10-12】冒泡排序(层层优化改进)

  1. 原理
    每次循环找出一个最大的元素(动态演示
  2. 第一版冒泡
java 复制代码
public class Maopao1 {
    public static void main(String[] args) {
        long start= System.currentTimeMillis();
        int[] arr2 = {11, 23, 69, 99, 1, 3, 45, 67, 5, 234, 678, 999, 7, 123};
        int[] result = maopao(arr2);
        System.out.println(Arrays.toString(result));

        System.out.println(System.currentTimeMillis()-start);
    }

    private static int[] maopao(int[] arr2) {
        for (int i = 0; i < arr2.length - 1; i++) {
            for (int j = 0; j < arr2.length - 1; j++) {
                if (arr2[j] > arr2[j + 1]) {
                    swap(arr2, j, j + 1);
                }
            }
            System.out.println(Arrays.toString(arr2));
        }
        System.out.println("循环了" +( arr2.length-1) + "次");
        return arr2;
    }

    public static void swap(int[] a, int i, int j) {
        int t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
}
  1. 改进一:内层循环的次数与外层循环有关系,将a.length-1变成a.length-1-i,可以每次循环后减少一次循环次数。
java 复制代码
public class Maopao2 {
    public static void main(String[] args) {

        long start = System.currentTimeMillis();
        int[] arr2 = {11, 23, 69, 99, 1, 3, 45, 67, 5, 234, 678, 999, 7, 123};
        int[] result = maopao(arr2);
        System.out.println(Arrays.toString(result));
        System.out.println(System.currentTimeMillis()-start);
    }

    private static int[] maopao(int[] arr2) {
        for (int i = 0; i < arr2.length - 1; i++) {
            for (int j = 0; j < arr2.length - 1 - i; j++) {
                if (arr2[j] > arr2[j + 1]) {
                    swap(arr2, j, j + 1);
                }
            }
            System.out.println(Arrays.toString(arr2));
        }
        return arr2;
    }

    public static void swap(int[] a, int i, int j) {
        int t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
}
  1. 改进二,只要一轮比较没有发生交换,则可以提前结束冒泡,在本身有序的序列情况下,循环一次就行了
java 复制代码
public class Maopao2 {
    public static void main(String[] args) {

        long start = System.currentTimeMillis();
        int[] arr2 = {11, 23, 69, 99, 1, 3, 45, 67, 5, 234, 678, 999, 7, 123};
        int[] result = maopao(arr2);
        System.out.println(Arrays.toString(result));
        System.out.println(System.currentTimeMillis()-start);
    }

    private static int[] maopao(int[] arr2) {
        for (int i = 0; i < arr2.length - 1; i++) {
            boolean swapBool = false; // 发生交换
            for (int j = 0; j < arr2.length - 1 - i; j++) {
                if (arr2[j] > arr2[j + 1]) {
                    swap(arr2, j, j + 1);
                    swapBool = true;
                }
            }
            if (!swapBool) {
                System.out.println("循环了" + i + "次");
                break;
            }
            System.out.println(Arrays.toString(arr2));
        }
        return arr2;
    }

    public static void swap(int[] a, int i, int j) {
        int t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
}
  1. 改进三,只需要内层循环,外层使用while(ture),用内层最后一个交换的索引来退出循环,如果最后交换的索引等于0的话说明没有交换,推出循环;
java 复制代码
public class Maopao3 {
    public static void main(String[] args) {

        long start = System.currentTimeMillis();
        int[] arr2 = {11, 23, 69, 99, 1, 3, 45, 67, 5, 234, 678, 7, 123,999};
        int[] result = maopao(arr2);
        System.out.println(Arrays.toString(result));

        System.out.println(System.currentTimeMillis()-start);
    }

    private static int[] maopao(int[] arr2) {
        int n = arr2.length - 1;
        int num = 0;
        while (true) {
            int last = 0; // 最后一次交换的索引
            for (int j = 0; j < n; j++) {
                if (arr2[j] > arr2[j + 1]) {
                    swap(arr2, j, j + 1);
                    last = j;
                }
            }
            n = last;
            num++;
            if (n == 0) {
                break;
            }
            System.out.println(Arrays.toString(arr2));
        }
        System.out.println("循环了" + num + "次");
        return arr2;
    }

    public static void swap(int[] a, int i, int j) {
        int t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
}
相关推荐
火锅机器13 分钟前
java 8 lambda表达式对list进行分组
java·开发语言·list
我是华为OD~HR~栗栗呀38 分钟前
华为od-22届考研-测试面经
java·c++·python·功能测试·华为od·华为·面试
康谋自动驾驶40 分钟前
拆解3D Gaussian Splatting:原理框架、实战 demo 与自驾仿真落地探索!
算法·数学建模·3d·自动驾驶·汽车
是梦终空1 小时前
计算机毕业设计241—基于Java+Springboot+vue的爱心公益服务系统(源代码+数据库+11000字文档)
java·spring boot·vue·毕业设计·课程设计·毕业论文·爱心公益系统
_殊途1 小时前
项目开发手册-项目结构
java
keke_俩个科1 小时前
ShardingSphere分库分表基础配置与使用说明
java·数据库·分布式·spring
爬虫程序猿1 小时前
把“天猫”装进 JVM:Java 关键词商品爬虫从 0 到 1(含完整可运行代码)
java·jvm·爬虫
java_logo1 小时前
Docker 部署微服务项目保姆级教程
java·运维·docker·微服务·容器·eureka·架构
oak隔壁找我1 小时前
Servlet 三大组件详解
java·后端
南部余额1 小时前
Spring MVC 拦截器interceptor
java·spring·mvc