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;
    }
相关推荐
电饭叔19 分钟前
《python语言程序设计》2018版第8章19题几何Rectangle2D类(下)-头疼的几何和数学
开发语言·python
Eternal-Student20 分钟前
everyday_question dq20240731
开发语言·arm开发·php
极客先躯24 分钟前
高级java每日一道面试题-2024年10月3日-分布式篇-分布式系统中的容错策略都有哪些?
java·分布式·版本控制·共识算法·超时重试·心跳检测·容错策略
卑微求AC36 分钟前
(C语言贪吃蛇)11.贪吃蛇方向移动和刷新界面一起实现面临的问题
c语言·开发语言
夜月行者1 小时前
如何使用ssm实现基于SSM的宠物服务平台的设计与实现+vue
java·后端·ssm
程序猿小D1 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
Yvemil71 小时前
RabbitMQ 入门到精通指南
开发语言·后端·ruby
潘多编程1 小时前
Java中的状态机实现:使用Spring State Machine管理复杂状态流转
java·开发语言·spring
_阿伟_1 小时前
SpringMVC
java·spring
代码在改了1 小时前
springboot厨房达人美食分享平台(源码+文档+调试+答疑)
java·spring boot