百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Java排序之冒泡排序(java冒泡排序选择排序)

myzbx 2025-07-02 23:18 24 浏览

今天来给大家介绍一下排序算法之冒泡排序

jwt简介

冒泡排序:(Bubble Sort)是一种简单的交换排序。之所以叫做冒泡排序,因为我们可以把每个元素当成一个小气泡,根据气泡大小,一步一步移动到队伍的一端,最后形成一定对的顺序。

冒泡排序的原理:

我们以一个队伍站队为例,教官第一次给队员排队是无序的,这时候就需要排队,按矮到高的顺序排列,首先拎出第一第二个比较,如果第一个队员比第二个要高,则两个交换位置, 高的放到排到第二个位置,矮的就排到第一个,再把第二个,第三个比较,把高的排到后面一个位置,然后以此类推,直至第一轮所有队员都比较过一次(记住每次比较都是相邻的两个),这样就可以把最高的排到最后的位置。

总结就是: 每一轮都需要从第一位开始进行相邻的两个数的比较,将较大的数放后面,比较完毕之后向后挪一位继续比较下面两个相邻的两个数大小关系,重复此步骤,直到最后一个还没归位的数。

冒泡排序流程图

我们进行分解看看每一步是怎么执行的

首先我们给个无序数组 [3,14,32,16,53,8] 进行升序排序

  • 第一轮:初始值 [3,14,32,16,53,8]

如图所示,走完第一轮之后,我们得到的结果就是[3,14,16,32,8,53],此时已经将最大的数53排到了指定位置,所以冒泡排序每一轮只能确定将一个数归位。即第一趟只能确定将末位上的数归位, 第二趟只能将倒数第 2 位上的数归位,依次类推下去

  • 第二轮:初始值 [3,14,16,32,8,53]第二轮排序结果[3,14,16,8,32,53]
  • 第三轮:初始值 [3,14,16,8,32,53]第三轮排序结果[3,14,8,16,32,53]
  • 第四轮:初始值 [3,14,8,16,32,53]第四轮排序结果[3,8,14,16,32,53]
  • 第五轮:初始值 [3,8,14,16,32,53]第五轮排序结果[3,8,14,16,32,53] 到这,我们最终排序完成。

Java代码实现:

 public static void bubbleSort(int[] array){
         for(int i=0;i<array.length-1;i++){//控制比较轮次,一共 n-1 趟
             int num = 0; //用来记录比每轮比较的次数
             for(int j=0;j<array.length-1;j++){//控制两个挨着的元素进行比较
                 if(array[j] > array[j+1]){
                   //换位
                     int temp = array[j];
                     array[j] = array[j+1];
                     array[j+1] = temp;
                 }
                 //比较一次,加1
                 num =num+1;
 
             }
             //结果输出
             System.out.print("第"+(i+1)+"轮:[");
             for (int a=0;a<array.length; a++){
                 if(a!=array.length-1)
                 {
                     System.out.print(array[a]+",");
                 }else{
                     System.out.print(array[a]+"]");
                 }
             }
             System.out.println(",比较了:"+num+" 次");
         }
     }

输出结果

   第1轮结果:[3,14,16,32,8,53],每轮比较了:5 次
   第2轮结果:[3,14,16,8,32,53],每轮比较了:5 次
   第3轮结果:[3,14,8,16,32,53],每轮比较了:5 次
   第4轮结果:[3,8,14,16,32,53],每轮比较了:5 次
   第5轮结果:[3,8,14,16,32,53],每轮比较了:5 次

我在每轮比较的时候定义了一个num来记录比较次数,大家可以看到长度为6的数组比较,比较了5轮,每轮都比较了5次, 但是通过上面拆分的每一轮比较细节可以看出,其实约到后面的比较,有一部分已经是排好了,如果某个数比他的下一个位置还小, 就没有必要和后面已经排好的数据再做比较,这样只会增加程序运行压力。

比如,第四轮,8和14比较,换位之后,16,32,53都已经排好了,14再和16比较,不用换位,那16之后的数据已经在第三轮排好,就没必要再比较16和32,32和53了。

那我们来对程序做一个优化,其实在第一轮把最大的数字排到最后之后,第二轮就不用再和最后一个数字比较,因为最大的数字已经排好,再比较也只能排在最后一位之前了。

优化: 我们就在程序内层循环做一个限制,每轮比较之后,下一轮就比较到array.length-1-i的位置。就是第一轮6位数都比较完成,最大排在最后,第二轮就比较前五个数,把前五个数中最大的排在第五位。这样以此类推,就可以减少程序中无用的比较。

优化代码如下:

   public static void bubbleSort(int[] array){
         for(int i=0;i<array.length-1;i++){//控制比较轮次,一共 n-1 趟
             int num = 0; //用来记录比每轮比较的次数
             //每一轮比较一次就排除最后一位,每轮的最后一位一定是这轮最大的,所以-i,
             for(int j=0;j<array.length-1-i;j++){//控制两个挨着的元素进行比较
                  //换位
                     int temp = array[j];
                     array[j] = array[j+1];
                     array[j+1] = temp;
                 }
                 //比较一次,加1
                 num =num+1;
 
             }
             //结果输出
             System.out.print("第"+(i+1)+"轮结果:[");
             for (int a=0;a<array.length; a++){
                 if(a!=array.length-1)
                 {
                     System.out.print(array[a]+",");
                 }else{
                     System.out.print(array[a]+"]");
                 }
             }
             System.out.println(",每轮比较了:"+num+" 次");
         }
     }

我们再来看看结果:

第1轮结果:[3,14,16,32,8,53],每轮比较了:5 次
第2轮结果:[3,14,16,8,32,53],每轮比较了:4 次
第3轮结果:[3,14,8,16,32,53],每轮比较了:3 次
第4轮结果:[3,8,14,16,32,53],每轮比较了:2 次
第5轮结果:[3,8,14,16,32,53],每轮比较了:1 次

由此,我们可以看到,由之前30次比较减少到15次,所以程序压力会少很多,程序复杂度也降低了。由上面结果可知:6位长度的数组需要排五轮,每轮次数减1,那如果由n个长度的数组,需要比较多少次呢?

  1. 第一轮:6-1
  2. 第二轮:6-2
  3. 第三轮:6-3
  4. 倒数第二轮:2
  5. 倒数第一轮:1

得出结果:(n-1)+(n-2)+...+2+1 = n(n-1)/2 =1/2n^2 -1/2n
是一个等差数列,按照时间复杂度规则,直接取最高阶项并去除常熟系数等到时间复杂度就是 O(n^2)了

到这,我们的冒泡排序就了解完了。

相关推荐

半导体行业术语缩写词典总结-JKL_半导体词汇缩写表

作为半导体行业新人来说,最痛苦的莫过于各种缩写词术语了,有的缩写词一样但是会有不同的解释。这里作者给大家整理了部分术语词典,后面会按照更新顺序一一分享出来。废话不多说,直接开始,如有遗漏,欢迎大家在评...

JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech

ToraOne,thesecond-generationmultidimensionaltactilehumanoidrobotdevelopedbyPaXiniTechTMTPOS...

Hong Kong&#39;s Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants

AI-generatedimageTMTPOST--StrollthroughthestreetsofHongKongtoday,anditmightfeellikey...

http2解决了哪些问题_简述http2的优点

HTTP/2(最初称为SPDY)是HTTP协议的第二个主要版本,它在HTTP/1.1的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是HTTP/2主要解决的问题:队头阻...

China&#39;s economy stays strong and vital amid pressure

Peoplevisitthe4thChina-CEECExpo&InternationalConsumerGoodsFairinNingbo,eastChina's...

JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire

TMTPOST--JD.comhasunveiledplanstoacquireGermany’sCeconomyAG—theparentofEurope’sleading...

深入剖析 Java 中的装饰器设计模式:原理、应用与实践

在Java软件开发的广阔天地里,设计模式犹如璀璨星辰,照亮我们构建高效、可维护系统的道路。今天,让我们聚焦于其中一颗闪耀的星——装饰器设计模式,深入探究它的奥秘,看看如何利用它为我们的代码赋予...

组合模式应用-适配器模式_适配器组件

写在前面Hello,我是易元,这篇文章是我学习设计模式时的笔记和心得体会。如果其中有错误,欢迎大家留言指正!该部分为各模式组合使用,涉及代码较多,熟能生巧。内容回顾定义适配器模式是一种结构型设计模式,...

OOM (Out Of Memory) 故障排查指南

1.确认OOM类型首先需要确认是哪种类型的OOM:JavaHeapOOM:Java堆内存不足NativeMemoryOOM:本地内存不足MetaspaceOOM:元空间内存不足Contai...

刷完这49题,面试官当场给Offer!Java程序员必备指南

1.问题:如果main方法被声明为private会怎样?答案:能正常编译,但运行的时候会提示”main方法不是public的”。2.问题:Java里的传引用和传值的区别是什么?答案:传引用是指传递的是...

C#编程基础(看这一篇就够了)_c#编程入门与应用

C#及其开发环境简介C#概述C#是一个现代的、通用的、面向对象的编程语言,由微软(Microsoft)开发,经Ecma和ISO核准认可。它由AndersHejlsberg和他的团队在.NET框架开发...

说一下JDK的监控和 线上处理的一些case

一句话总结JDK监控常用工具包括JConsole、VisualVM、JMC等,用于实时查看内存、线程、GC状态。线上常见问题处理:内存泄漏通过heapdump分析对象引用链;频繁GC可调整-Xmx/...

JavaScript深拷贝极简指南:3种方法解决嵌套与循环引用难题

为什么需要深拷贝?首先我们看看浅拷贝,point指向的是同一个地址,这时我们修改obj2.point的属性时,obj1的point属性也会被修改再看看深拷贝,point指向的是不同地址,这时我们修改o...

Java 25 在 JEP 519 中集成了紧凑对象头

作者|ANMBazlurRahman译者|刘雅梦策划|丁晓昀Java25通过JEP519将紧凑对象头作为产品特性进行了集成,在不需要更改任何代码的情况下,为开发人员提供了...

每日一练 Python 面试题(1)_python每日一记

以下是5道Python基本语法相关的面试题,涵盖变量、运算符、数据结构、函数和异常处理等核心概念:1.变量与作用域题目:以下代码的输出是什么?解释原因。x=10deffunc():...