网站首页 > 精选教程 正文
在日常开发中经常会遇到一类问题,就是对一个集合的数据进行排序
掌握一些排序算法,对于日常开发是非常有帮助的
今天介绍一下冒泡排序法
算法逻辑
时间复杂度
由上图逻辑可以得出,冒泡排序的循环次数为
由循环次数可以得出,冒泡排序的时间复杂度为
空间复杂度
由上图逻辑可以得出,冒泡排序每次交换所使用的临时变量为 i,j,tmp
由临时变量数可以得出,冒泡排序的空间复杂度为
java代码实现
public int[] sortByBubble(int[] data) {
//获取数组总长度
int size = data.length;
for (int i = 0; i < size; i++) {
for (int j = 0; j < size - i - 1; j++) {
//Todo: 请关注这里
//if判断里使用 “>” 代表从小到大排序
//if判断里使用 “<” 代表从大到小排序
if (data[j] > data[j + 1]) {
int tmp = data[j];
data[j] = data[j + 1];
data[j + 1] = tmp;
}
}
}
return data;
}
小结
今天主要介绍了单集合排序的一种排序算法——冒泡排序
小伙伴们都了解了吗?
下次小Top将继续介绍单集合排序算法
对于今天的内容有任何疑问或问题,欢迎留言或讨论 ^-^
- 上一篇: 五十四、最基础的冒泡排序
- 下一篇: Python实现冒泡排序
猜你喜欢
- 2024-12-04 程序入门:冒泡排序(C++)
- 2024-12-04 算法学习-JavaScript冒泡排序与选择排序
- 2024-12-04 西门子SCL编程实例——冒泡排序算法(更新版)
- 2024-12-04 python冒泡排序
- 2024-12-04 C语言 冒泡排序
- 2024-12-04 Python中的关键算法之”冒泡排序“
- 2024-12-04 西门子SCL语言编程实例——冒泡排序
- 2024-12-04 宇哥编程算法练习:冒泡排序的原理(基于Access数据库VBA)
- 2024-12-04 看动画学算法之:排序-冒泡排序
- 2024-12-04 西门子SCL编程实例—冒泡排序算法的实现
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)