最全java实现Bubble冒泡排序详解(java面试必背),初次走上技术管理岗位的思考总结

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

大厂面试真题:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

import java.util.Arrays;

/**

  • @author 王恒杰

  • @version 1.0

  • @date 2021/9/22 8:55

  • @email 1078993387@qq.com

  • @Address 天津

  • @Description:

*/

public class TestBubble {

public static void main(String[] args) {

Integer[] arr={9,8,7,65,4,3,2,12};

Bubble.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

四、冒泡排序的时间复杂度分析

冒泡排序使用了双层for循环,其中内层循环的循环体是真正完成排序的代码,所以,我们分析冒泡排序的时间复杂度,主要分析一下内层循环体的执行次数即可。

在最坏情况下,也就是假如要排序的元素为{6,5,4,3,2,1}逆序,那么:

元素比较的次数为:

(N-1)+(N-2)+(N-3)+…+2+1=((N-1)+1)*(N-1)/2=N^2/2-N/2;

元素交换的次数为:

(N-1)+(N-2)+(N-3)+…+2+1=((N-1)+1)*(N-1)/2=N^2/2-N/2;

总执行次数为:

(N2/2-N/2)+(N2/2-N/2)=N^2-N;

按照大O推导法则,保留函数中的最高阶项那么最终冒泡排序的时间复杂度为O(N^2).

五、冒泡排序综合题:

  • 排序规则:数组两个相邻的元素依次比较,每次将最大的数值放到最后的位置

该图片详细记录冒泡排序执行流程,图是王宇希老师所做

该图片详细记录冒泡排序执行流程,图是王宇希老师所画

  • 代码实现

package com.tjcu;

import java.util.Arrays;

/**

  • @author 王恒杰

  • @version 1.0

  • @date 2021/9/22 9:47

  • @email 1078993387@qq.com

  • @Address 天津

  • @Description:

*/

public class BubbleDemo1 {

public static void main(String[] args) {

int[] a={1,2,3,4,56,7,8};

// 比较轮数应该是n-1

for (int i = 1; i <a.length ; i++) {

// 元素比较

for(int j=0;j<a.length-1;j++){

if (a[j] > a[j+1]) {

int temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

}

System.out.println(Arrays.toString(a));

}

}

  • 优化一(减少头部有序区验证)

优化思想:如果本轮有交换则继续排序,如果本轮没交换则认为数组已称为有序数组,跳出大循环。

package com.tjcu;

import java.util.Arrays;

/**

  • @author 王恒杰

  • @version 1.0

  • @date 2021/9/22 9:47

  • @email 1078993387@qq.com

  • @Address 天津

  • @Description:

*/

public class BubbleDemo1 {

public static void main(String[] args) {

int[] a={1,2,8,4,56,7,9};

// 比较轮数应该是n-1

for (int i = 1; i <a.length ; i++) {

// 元素比较

Boolean isSort=true;

for(int j=0;j<a.length-1;j++){

if (a[j] > a[j+1]) {

int temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

isSort=false;

}

if(isSort){

break;

};

}

}

System.out.println(Arrays.toString(a));

}

}

  • 优化二(减少尾部有序区验证)

优化思想:每次排序记录最后一次交换元素的位置,确认无序区边界,下次排序以边界为结束条件,减少多余的验证。

int[] a = {3,4,2,1,5,6,7,8};

int lastIndex = 0;

int sortedIndex = a.length -1;

for (int i = 1; i < a.length; i++) {

//有序标记,每一轮的初始是true

boolean isSorted = true;

for(int j=0; j<sortedIndex; j++){

if(a[j]>a[j+1]){

//交换元素位置

int temp = a[j];

a[j] = a[j+1];

a[j+1] = temp;

lastIndex= j+1;//记录最后一次修改元素的位置,确认有序区边界

//有元素交换,所以不是有序,标记变为false

isSorted = false;

}

sortedIndex = lastIndex;//有序区边界作为下次比较的结束位置

}

//如果没有交换isSorted为true,选择跳出循环,结束排序

if(isSorted) break;

}

六、从大到小排序

===========================================================================

package com.tjcu;

import java.util.Arrays;

/**

  • @author 王恒杰

  • @version 1.0

  • @date 2021/9/22 20:48

  • @email 1078993387@qq.com

  • @Address 天津

  • @Description:

*/

public class BubbleTest1 {

public static void main(String[] args) {

int[] a={1,36,4,10,39,67};

// 控制轮数

最后

做任何事情都要用心,要非常关注细节。看起来不起眼的、繁琐的工作做透了会有意想不到的价值。
当然要想成为一个技术大牛也需要一定的思想格局,思想决定未来你要往哪个方向去走, 建议多看一些人生规划方面的书籍,多学习名人的思想格局,未来你的路会走的更远。

更多的技术点思维导图我已经做了一个整理,涵盖了当下互联网最流行99%的技术点,在这里我将这份导图分享出来,以及为金九银十准备的一整套面试体系,上到集合,下到分布式微服务

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

[外链图片转存中…(img-bBZQ9hWO-1715568315545)]

[外链图片转存中…(img-BofVpaEH-1715568315545)]

[外链图片转存中…(img-BkJRV6M0-1715568315545)]

[外链图片转存中…(img-6GdHSYeQ-1715568315545)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 12
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java项目 打包成 exe 可执行文件! 如何打包跨平台的.exe文件。安装后运行左窗窗口标有十步。 第1步 : 完全略过,直接点Next 第2步 : 我们选择“JAR in EXE mode” 就是选择我们已经有制作好的jar文件。 第3步 : 上面是项目名称,可随便填写,下面一个写出你想要将打包后的exe文件输出的目录我的是“桌面\project\”。 第4步 : 由于我的演示程序是图形的,所以选第一个,如果你的程序是控制台的,则选择第二个,Executable name写你将要生成的.exe文件的名字,Icon File可以选择生成文件的图标。 第5步 : 先别管上面的,先在下面单击绿色的“+”号,在弹出的窗口中点Archive,然后找到起初已经做好的 CAMP_fat.jar(详见1.3)文件,"OK"后返回,在下面的Class Path里就出现jar文件路径后,再在上面Main Class栏内点击找到main所在的类。 第6步 : 你系统的JRE版本,一般是填个1.3,下面填1.6在这里单击advanced options,选择search sequence。选这个就是因为我们要把JDK环境也打包进来,好让程序能跨平台使用。首先要从你系统的JDK下的JRE目录copy到你.exe文件的输出目录下“桌面\project\JRE”,然后回到exe4j中在弹出窗口删除列表中的所有项。我的是三项,一个注册表的,一个JAVA环境变量的,一个JDK环境变量的,都不要。然后单击绿“+”,选择directory并选择JRE的根目录,我的是“桌面\project\JRE”就是 copy后的目录,选完后exe4j弹出窗口中的Directory里会显示“.\JRE”。点OK关闭该窗口,返回exe4j的主窗口,你就可以看到刚加的路径。再从主窗口左侧窗口中单击advanced options,并选择preferred VM,在弹出的窗口中选择client hostspot VM,单击next按钮继续。 第7、8步 : 是一些个性设置默认即可。 第9步 : 编译 第10步 : 你点那个“Click Here to Start the Application”按钮就可以看到程序运行效果了,然后再点”Seave as”保存一个exe4j生成的一个文件,随便存哪里都行,和我们的.exe程序无关。
### 回答1: 冒泡排序是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。 这是使用 Java 实现冒泡排序的代码示例: ``` public static void bubbleSort(int[] arr) { int n = arr.length; for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { // 交换 arr[j] 和 arr[j + 1] int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } ``` 该代码实现冒泡排序算法的基本逻辑,它通过两个嵌套的循环来遍历整个数组,并通过交换顺序错误的元素来排序数组。 ### 回答2: 冒泡排序是一种基础的排序算法,它通过不断比较相邻的两个元素,将较大的元素逐渐交换到右边,达到排序的目的。 使用Java实现冒泡排序的步骤如下: 1. 首先,创建一个整型数组来存储需要排序的元素。 2. 使用一个for循环来遍历数组,外层循环控制比较的轮数,总共需要比较数组长度减1次。 3. 在每一轮比较中,再使用一个内层循环来比较相邻的元素,内层循环控制每一轮需要比较的次数。 4. 比较相邻的两个元素,如果前面的元素比后面的元素大,则交换它们的位置。 5. 继续进行下一轮的比较,直到所有的元素都排好序。 下面是Java代码实现冒泡排序: ```java public class BubbleSort { public static void main(String[] args) { int[] arr = {5, 2, 8, 3, 1}; for (int i = 0; i < arr.length - 1; i++) { for (int j = 0; j < arr.length - 1 - i; j++) { if (arr[j] > arr[j + 1]) { // 交换两个元素的位置 int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } // 输出排序结果 for (int num : arr) { System.out.print(num + " "); } } } ``` 以上代码的输出结果为:1 2 3 5 8,表示已经成功对数组进行了冒泡排序冒泡排序的时间复杂度为O(n^2),是一种相对简单但效率较低的排序算法。 ### 回答3: 冒泡排序Bubble Sort)是一种简单的排序算法,通过不断地交换相邻的元素来实现排序。 首先,我们需要定义一个用于存储待排序元素的数组。假设我们有一个整数数组arr,大小为n。 接下来,我们需要使用两个嵌套循环来比较和交换数组中的元素。外部循环控制排序的轮数,而内部循环用于比较相邻元素并进行交换。 下面是使用Java实现冒泡排序的代码: ```java public class BubbleSort { public static void bubbleSort(int[] arr) { int n = arr.length; for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { // 交换arr[j]和arr[j+1] int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } public static void main(String[] args) { int[] arr = {64, 34, 25, 12, 22, 11, 90}; bubbleSort(arr); System.out.println("排序后的数组:"); for (int i = 0; i < arr.length; i++) { System.out.print(arr[i] + " "); } } } ``` 以上代码定义了一个名为BubbleSort的类,其中包含了实现冒泡排序的方法bubbleSort。在main方法中,我们创建了一个包含一些整数的数组arr,并调用bubbleSort方法对其进行排序。最后,我们将排序后的数组打印出来。 执行以上代码,输出结果将为: 排序后的数组:11 12 22 25 34 64 90 以上就是使用Java实现冒泡排序的方法。冒泡排序算法的时间复杂度为O(n^2),虽然效率较低,但对于小规模的数据排序仍然是一种较好的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值