0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

jwt冒泡排序的原理

科技绿洲 来源:Java技术指北 作者:Java技术指北 2023-09-25 16:33 次阅读

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)了

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

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • JAVA
    +关注

    关注

    19

    文章

    2904

    浏览量

    102996
  • 程序
    +关注

    关注

    114

    文章

    3631

    浏览量

    79548
  • 代码
    +关注

    关注

    30

    文章

    4556

    浏览量

    66784
收藏 人收藏

    评论

    相关推荐

    FPGA排序-冒泡排序介绍

    排序算法是图像处理中经常使用一种算法,常见的排序算法有插入排序、希尔排序、选择排序冒泡
    发表于 07-17 10:12 671次阅读
    FPGA<b class='flag-5'>排序</b>-<b class='flag-5'>冒泡</b><b class='flag-5'>排序</b>介绍

    labview 版的冒泡排序

    labview 版的冒泡排序,只是想用Labview表达冒泡法的思想,
    发表于 06-05 11:18

    冒泡排序

    package algorithms// 冒泡排序// 冒泡排序算法的运作如下:// 比较相邻的元素。如果第一个比第二个大,就交换他们两个。// 对每一对相邻元素作同样的工作,从开始第
    发表于 10-17 19:03

    冒泡排序法三部曲の一、冒泡排序原理版

    的bubble sort(冒泡排序)原理类似于气泡上升过程,到自身的密度小于上一层介质则上升,排序同理。以数组{5,4,3,2,1}为例: 第一轮:由于5大于4,则5右移一位,5大于3,则继续右移,5>2
    发表于 09-12 10:30

    冒泡排序法三部曲の冒泡排序原理版(一)

    [table][tr][td]声明:编译环境为VS2017 语言:C language针对对象:对n个数从小到大进行排序(从大到小同理)思路分析:经典的bubble sort(冒泡排序)原理类似于
    发表于 09-12 10:42

    Java冒泡排序的原理是什么?

    Java冒泡排序的原理
    发表于 11-06 07:12

    冒泡排序法的具体实现方法是什么?

    什么是冒泡排序冒泡排序法的具体实现方法是什么?
    发表于 07-15 06:48

    冒泡排序法的泛型实现

    冒泡排序法的泛型实现,自用笔记!
    发表于 01-20 07:22

    C语言教程之冒泡排序

    C语言教程之冒泡排序,很好的C语言资料,快来学习吧。
    发表于 04-22 11:06 0次下载

    一文了解冒泡排序

    冒泡排序是一种交换排序。 什么是交换排序呢? 交换排序:两两比较待排序的关键字,并交
    的头像 发表于 01-17 12:47 2861次阅读
    一文了解<b class='flag-5'>冒泡</b><b class='flag-5'>排序</b>

    揭秘冒泡排序、交换排序和插入排序

    01 — 冒泡排序 在实现冒泡排序代码之前我们先理解一下什么是冒泡排序,我们举一个现实生活中的例
    的头像 发表于 06-18 09:57 1309次阅读

    C语言冒泡排序工程代码汇总

    C语言冒泡排序工程代码汇总
    发表于 08-30 11:06 3次下载

    冒泡排序的基本思想

    冒泡排序的英文Bubble Sort,是一种最基础的交换排序。之所以叫做冒泡排序,因为每一个元素都可以像小气泡一样,根据自身大小一点一点向数
    的头像 发表于 01-20 11:38 5226次阅读
    <b class='flag-5'>冒泡</b><b class='flag-5'>排序</b>的基本思想

    php版冒泡排序是如何实现的?

    无论学习哪一种编程语言,进行算法方面的训练时都绕不开“排序”。排序在进阶编程中有非常广泛的应用,要想成为编程高手,排序算法是必须要掌握的。而冒泡排序
    的头像 发表于 01-20 10:39 657次阅读
    php版<b class='flag-5'>冒泡</b><b class='flag-5'>排序</b>是如何实现的?

    怎样运用Java实现冒泡排序和Arrays排序出来

    在数据结构中我们学习了解了冒泡排序和Arrays排序的基本算法,但没能够用编程语言实现出来。那我们应该怎样运用Java通过编程语言将冒泡排序
    的头像 发表于 03-02 09:37 325次阅读
    怎样运用Java实现<b class='flag-5'>冒泡</b><b class='flag-5'>排序</b>和Arrays<b class='flag-5'>排序</b>出来