Java冒泡排序的定义与实例代码
作者:小皮蛋^_^ 发布时间:2022-03-29 12:32:31
标签: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;
}
运行结果:
来源:https://blog.csdn.net/qq_44104879/article/details/110571007


猜你喜欢
- 定义Java修饰符:修饰符用来定义类、方法或者变量,通常放在语句的最前端。分类主要分为2类:访问控制修饰符非访问控制修饰符访问控制修饰符可以
- 场景:有一个喜欢吃饺子,他有三种不同的方式去吃,蒸饺子,煮饺子,煎饺子,想要用策略模式来设计这个场景,怎么弄?1.复习简单工厂模式具体的代码
- 下面提供代码示例,请参考。public boolean onKeyDown(int keyCode, KeyEvent event) {&n
- 在本篇博文中,我们主要讲解一下 IntelliJ IDEA 安装目录中的一些核心文件的功能及用法:如上图所示,我们定位到了 IntelliJ
- 一、使用Optional引言1.1、代码问题引出在写程序的时候一般都遇到过 NullPointerException,所以经常会对程序进行非
- 问题描述:idea输入中文,没输入几个拼音就好像自动回车,有时得到几个字母,然后就不能输入拼音了。遇到这个情况就导致输入中文特别困难,可以采
- 话不多说,请看代码:<!DOCTYPE html><html><head> <meta
- 如果你发现在一个接口使用有如下定义方法: public String[] getParameters();那么你应该认
- 1.简介建议阅读本文最好对Dokcer有一些了解首先我们先了解一下Docker是什么Docker 属于 Linux 容器的一种封装,提供简单
- Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,是一种比较常用
- 本文实例为大家分享了Unity实现Flappy Bird游戏的具体代码,供大家参考,具体内容如下参考:腾讯课程(零基础制作像素鸟) 环境:U
- 运算符运算符,顾名思义就是用来执行数学运算的。在Java中运算符可以分为:算术运算符、关系运算符、逻辑运算符、位运算符、移位运算符、条件运算
- 用java压缩/解压文件: import java.io.*; import java.awt.*; import java.aw
- 1、找奇数:public static boolean isOdd(int i){ return i % 2 == 1; }上面的方法真
- 场景随着移动支付的兴起,在我们的app'中,会经常有集成支付的需求.这时候一般都会采用微信和支付宝的sdk 来集成(一)支付宝支付在
- 在项目中引入springcloud中的gateway时报以下错误Description:Parameter 0 of method modi
- Java的List在删除元素时,一般会用list.remove(o)/remove(i)方法。在使用时,容易触碰陷阱,得到意想不到的结果。总
- Spring @Configuration 和 @Component 区别一句话概括就是 @Configuration 中所有带 @Bean
- ListView是android中最常用的控件之一。 在实际运用中往往会遇到一次性加载全部数据过多,需要分页加载增加程序运行效率! 本dem
- 一、默认异常处理机制默认情况下,SpringBoot 提供 /error 请求,来处理所有异常的。1.浏览器客户端,请求头里的属性是Acce