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;
    }
相关推荐
风_流沙3 分钟前
java 对ElasticSearch数据库操作封装工具类(对你是否适用嘞)
java·数据库·elasticsearch
charlie1145141917 分钟前
C++ STL CookBook
开发语言·c++·stl·c++20
袁袁袁袁满7 分钟前
100天精通Python(爬虫篇)——第113天:‌爬虫基础模块之urllib详细教程大全
开发语言·爬虫·python·网络爬虫·爬虫实战·urllib·urllib模块教程
ELI_He99913 分钟前
PHP中替换某个包或某个类
开发语言·php
m0_7482361121 分钟前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
倔强的石头10629 分钟前
【C++指南】类和对象(九):内部类
开发语言·c++
ProtonBase32 分钟前
如何从 0 到 1 ,打造全新一代分布式数据架构
java·网络·数据库·数据仓库·分布式·云原生·架构
Watermelo61733 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v39 分钟前
leetCode43.字符串相乘
java·数据结构·算法
半盏茶香2 小时前
在21世纪的我用C语言探寻世界本质 ——编译和链接(编译环境和运行环境)
c语言·开发语言·c++·算法