【Java面试(二)】冒泡排序的实现及优化
创始人
2024-05-20 13:23:15
0

文章目录

  • 前言
    • 冒泡排序初步实现
    • 冒泡排序_优化_减少比较次数
    • 冒泡排序_优化_减少冒泡次数
    • 冒泡排序_优化_进一步优化比较次数
  • 总结

前言

  今天我们来学习与排序相关的面试题,首先我们先来学习冒泡排序,那什么是冒泡排序呢,它的关键在于数组中相邻元素进行比较,如果前一个小于后一个,它的位置可以不动,相反,则交换位置,依次两两进行相互比较,直到将数组中最大的元素放在最后的位置,每轮冒泡的结果就是将最大的元素放在数组的最后边,直到数组变为升序数组为止🎈🎈。

冒泡排序初步实现

  我们知道冒泡排序需要两两比较,然后可能会交换顺序,所以我们需要自己定义一个静态方法swap()实现交换顺序的功能,同样再写一个bubble()方法实现冒泡排序,最后在主方法中调用,每轮冒泡排序需要比较数组长度-1次,一共需要进行数组长度-1次冒泡排序,所以bubble()方法里边采用的是双重循环来实现的,下面是我们冒泡排序的初步代码👇👇。

public class BubbleSort {public static void main(String[] args) {int []a = {5,9,7,4,1,3,2,8};bubble(a);}public static void bubble(int []a){for (int j =0;j//一轮冒泡for (int i = 0; i < a.length-1 ; i++) {if(a[i]>a[i+1]){swap(a,i,i+1);}}System.out.println("第"+j+"轮冒泡"+Arrays.toString(a));}}public static void swap(int[]a,int i, int j){int t = a[i];a[i] = a[j];a[j] = t;}
}

在这里插入图片描述

  我们来分析一下代码,在冒泡排序中,我们每一次都是将数组最大的元素放在数组最后面,所以在进行下一轮冒泡排序的时候,数组最后边的元素已经是最大的了,所以不用再进行比较,所以我们接下来要对上边的代码进行优化💪💪。

冒泡排序_优化_减少比较次数

  接下来我们对冒泡排序的比较次数进行优化,上述代码中,第一轮冒泡排序需要比较七次,结果是将数组最大的元素9放在了数组最后的索引位置,第二轮冒泡排序时,就不用再与9进行比较,所以需要比较六次,以此类推,每一轮冒泡排序都会减少一次比较次数,我们总结出规律,将内层循环的次数改为i就可以减少比较次数了,结果相同,但是效率会更高🎉🎉。

public class BubbleSort {public static void main(String[] args) {int []a = {5,9,7,4,1,3,2,8};bubble(a);}public static void bubble(int []a){for (int j =0;j//一轮冒泡for (int i = 0; i < a.length-1-j ; i++) {if(a[i]>a[i+1]){swap(a,i,i+1);}}System.out.println("第"+j+"轮冒泡"+Arrays.toString(a));}}public static void swap(int[]a,int i, int j){int t = a[i];a[i] = a[j];a[j] = t;}
}

在这里插入图片描述

  我们分析运行结果,第四轮冒泡排序完成后,其实数组已经是一个升序数组了,不用再进行第五轮和第六轮冒泡排序了,所以我们还要对代码进行进一步的优化💪💪。

冒泡排序_优化_减少冒泡次数

  那怎么去进行优化呢,也就是怎么去判断你这个数组是有序的,什么时候能得到这个数组已经有序,不用冒泡了呢,我们可以这么来想,如果它某一轮冒泡排序,相邻元素两两进行比较,没有发生过一次交换,那是不是就证明数组已经有序了,那我们就可以以数组有没有交换作为判断依据,在代码中,我们可以在每次冒泡排序前,设置一个boolean swapped=false,表示还没有交换,然后在if()判断里边设置swapped=true表示如果发生了交换,就将swapped的值设置为true,最后在每次冒泡排序完成后·判断swapped的值是否为false·,如果为false,就break跳出外层循环,结束冒泡排序👇👇。

public class BubbleSort {public static void main(String[] args) {int []a = {5,9,7,4,1,3,2,8};bubble(a);}public static void bubble(int []a){for (int j =0;j//一轮冒泡boolean swapped = false;for (int i = 0; i < a.length-1-j ; i++) {System.out.println("比较次数"+i);if(a[i]>a[i+1]){swap(a,i,i+1);swapped = true;}}System.out.println("第"+j+"轮冒泡"+Arrays.toString(a));if(!swapped){break;}}}public static void swap(int[]a,int i, int j){int t = a[i];a[i] = a[j];a[j] = t;}
}

在这里插入图片描述

冒泡排序_优化_进一步优化比较次数

  虽然前边已经对冒泡排序进行了优化,但是还有一种比较特殊的情况,比如现在有一个无序数组:{5,2,7,4,1,3,8,9},在经历第一轮冒泡排序经历七次比较后变为{2,5,4,1,3,7,8,9},这个时候能确定的最大元素是9,接下来第二轮冒泡排序时,我们会发现仍然是需要比较六次,但是我们自己知道其实第二轮不用再比较六次,因为第一轮8跟9,5跟7都已经比较过了,所以下一轮冒泡排序的时候,没有必要再进行比较,所以我们要进一步优化✍️✍️。

  那怎么去优化呢,我们只需要在每次冒泡排序完记录最后一次交换发生的位置,来当做下一轮冒泡排序的比较次数🎉🎉。

public class BubbleSort {public static void main(String[] args) {int []a = {5,9,7,4,1,3,2,8};bubble_v2(a);}public static void bubble_v2(int[]a){int n = a.length-1;while (true) {int last=0;//表示最后一次交换索引的位置for (int i = 0; i < n; i++) {System.out.println("比较次数"+i);if(a[i]>a[i+1]){swap(a,i,i+1);last = i;}}n = last;System.out.println("第轮冒泡"+Arrays.toString(a));if(n==0){break;}}}public static void swap(int[]a,int i, int j){int t = a[i];a[i] = a[j];a[j] = t;}
}

在这里插入图片描述

总结

  以上就是我们Java面试过程中冒泡排序实现以及优化内容,最后,如果有什么错误的话,大家可以私信我📬📬,希望大家多多关注+点赞+收藏 ^_ ^🙏🙏,你们的鼓励是我不断前进的动力💪💪!!!

相关内容

热门资讯

最绚丽的安卓系统,最绚丽版本全... 哇,你知道吗?在安卓的世界里,有一款系统,它就像是一颗璀璨的明珠,闪耀着最绚丽的色彩。它就是——最绚...
小米系统安卓通知权限,深度解析... 亲爱的手机控们,你是否曾为手机通知栏里乱糟糟的信息而烦恼?又或者,你是否好奇过,为什么有些应用总是能...
安卓7.0系统能玩吗,体验全新... 你有没有想过,你的安卓手机升级到7.0系统后,那些曾经陪伴你度过无数时光的游戏,还能不能继续畅玩呢?...
平板安卓系统哪家好,安卓平板系... 你有没有想过,在这个科技飞速发展的时代,拥有一台性能出色的平板电脑是多么重要的事情呢?想象无论是追剧...
安卓好的点歌系统,打造个性化音... 你有没有想过,在安卓手机上,点歌系统竟然也能如此精彩?没错,就是那个我们每天都会用到,却又常常忽略的...
熊猫安卓系统直播软件,解锁互动... 你知道吗?最近有个超级酷炫的直播软件在熊猫迷们中间火得一塌糊涂!它就是熊猫安卓系统直播软件。别看它名...
安卓点播系统开发,Androi... 你有没有想过,手机里那些让你爱不释手的视频,其实背后有着一套复杂的安卓点播系统在默默支撑呢?今天,就...
安卓6.0系统加权限,深度解析... 你有没有发现,自从手机升级到安卓6.0系统后,权限管理变得超级严格呢?这可真是让人又爱又恨啊!今天,...
哪些电视带安卓系统,多款热门智... 你有没有想过,家里的电视竟然也能装上安卓系统?听起来是不是有点不可思议?没错,现在市面上就有不少电视...
苹果怎么运用安卓系统,揭秘如何... 你知道吗?最近有个大新闻在科技圈里炸开了锅,那就是苹果竟然开始运用安卓系统了!是不是觉得有点不可思议...
安卓系统能转什么系统好,探索最... 你有没有想过,你的安卓手机是不是也能换换口味,体验一下其他系统的魅力呢?没错,今天就来聊聊这个话题:...
龙之狂热安卓系统,释放龙族狂热 亲爱的手机控们,你是否曾为拥有一款独特的安卓系统而疯狂?今天,就让我带你走进一个充满奇幻色彩的龙之狂...
vivo手机安卓系统怎么升级系... 亲爱的手机控们,你是不是也和我一样,对手机的新功能充满期待呢?尤其是vivo手机的用户,是不是也在想...
鸿蒙2.0退回安卓系统,一场系... 你知道吗?最近科技圈里可是炸开了锅,因为华为的鸿蒙2.0操作系统竟然要退回安卓系统了!这可不是一个简...
安卓系统怎么复制卡,安卓系统卡... 你有没有遇到过这种情况:手机里的照片、视频或者重要文件,突然想备份到电脑上,却发现安卓系统的卡复制功...
app兼容低安卓系统,打造全民... 你有没有发现,现在手机APP更新换代的速度简直就像坐上了火箭!不过,你知道吗?有些APP可是特别贴心...
中间安卓系统叫什么,中间安卓系... 你有没有想过,安卓系统里竟然还有一个中间的版本?没错,就是那个让很多手机用户既熟悉又陌生的版本。今天...
安卓怎么用os系统,利用And... 你有没有想过,你的安卓手机其实可以变身成一个功能强大的操作系统呢?没错,就是那个我们平时在电脑上使用...
pe系统安卓能做么,探索安卓平... 亲爱的读者,你是否曾好奇过,那款在安卓设备上大受欢迎的PE系统,它究竟能做什么呢?今天,就让我带你一...
安卓 打印机系统,安卓打印机系... 你有没有想过,家里的安卓手机和打印机之间竟然能建立起如此紧密的联系?没错,就是那个安卓打印机系统!今...