Java冒泡排序的定义与实例代码

 更新时间:2020年12月04日 16:23:15   作者:小皮蛋^_^  
这篇文章主要给大家介绍了关于Java冒泡排序的定义与实例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

冒泡排序

在八大排序中,冒泡排序是最为出名的排序算法之一!

冒泡排序的代码还是相当简单的,两层循环,外层是冒泡轮数,里层是依次比较,这个算法的时间复杂度为O(n2);

冒泡排序的思想:

  • 比较数组中相邻的两个元素,如果第一个数比第二个数大,就交换它们的位置
  • 每一次比较都会产生一个最大或最小的元素
  • 下一次循环就只排序剩下的元素
  • 依次循环,直到所有元素排序完成

通过实例理解:

public static void main(String[] args) {
 int[] a={55,45,33,24,78,65,11};
 int[] sort = sorts(a);
 System.out.println(Arrays.toString(sort));
}

public static int[] sorts(int[] array){
 int a=0;
 //外层循环,判断要循环的次数,记录不需要比较的元素的个数;
 //在内层循环结束后,除去得到的元素,再重新让内层循环排序剩余的元素。
 for (int i=0;i<array.length-1;i++){
  /**
   * 内层循环,把每个相邻的元素比较一遍,后一个数大就交换位置,得到一个最小的元素,位于数组的最后。
   * j<array.length-1-i的意思是每把外层for循环走一次,内层for循环就得到一个相对最小的元素,
   * 那么下次循环就不再比较它,所以要—i
   * if语句是要把最小的元素放到array[j+1],这样数组就会从大到小排列
   */
  for (int j=0;j<array.length-1-i;j++){
   if (array[j+1]>array[j]){
    a=array[j];
    array[j]=array[j+1];
    array[j+1]=a;
   }
  }
 }
 return array;
}

运行结果:

总结

到此这篇关于Java冒泡排序的定义与实例的文章就介绍到这了,更多相关Java冒泡排序的定义与实例内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Springboot整合Swagger3全注解配置(springdoc-openapi-ui)

    Springboot整合Swagger3全注解配置(springdoc-openapi-ui)

    本文主要介绍了Springboot整合Swagger3全注解配置(springdoc-openapi-ui),文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • MybatisPlusInterceptor依赖变红如何解决,无法识别问题

    MybatisPlusInterceptor依赖变红如何解决,无法识别问题

    这篇文章主要介绍了MybatisPlusInterceptor依赖变红如何解决,无法识别问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Java 实例解析单例模式

    Java 实例解析单例模式

    单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式,这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建
    2021-11-11
  • Java中执行docker命令的实现示例

    Java中执行docker命令的实现示例

    本文主要介绍了Java中执行docker命令的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • 浅谈IDEA中Maven配置问题全解决

    浅谈IDEA中Maven配置问题全解决

    这篇文章主要介绍了浅谈IDEA中Maven配置问题全解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • 又一波Java专业人士必备书籍来袭

    又一波Java专业人士必备书籍来袭

    又一波Java专业人士必备书籍来袭,这篇文章主要向大家推荐了Java专业人士必读的书,感兴趣的小伙伴们不要错过
    2016-09-09
  • java合并多个文件的两种方法

    java合并多个文件的两种方法

    这篇文章主要为大家详细介绍了java合并多个文件的两种方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • SpringBoot多种自定义错误页面方式小结

    SpringBoot多种自定义错误页面方式小结

    这篇文章主要介绍了SpringBoot多种自定义错误页面方式小结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • java利用htmlparser获取html中想要的代码具体实现

    java利用htmlparser获取html中想要的代码具体实现

    这篇文章主要介绍了java利用htmlparser获取html中想要的代码具体实现,需要的朋友可以参考下
    2014-02-02
  • java中如何调用js

    java中如何调用js

    Nashorn是Java8中引入的一个新的JavaScript引擎,它允许在JVM上运行JavaScript代码,并且可以与Java代码相互调用,Nashorn遵循JSR233规范,是一个纯Java实现的JavaScript引擎,可以与Java程序无缝集成,提供动态脚本执行和灵活性
    2025-01-01

最新评论