网站首页 > java教程 正文
今天我们来了解下冒泡的的Java实现,我们从这几个方面入手:
- 原理介绍及时间复杂度
- Java代码实现
- 优化思考
一 、原理介绍

原理:每次比较两个相邻的元素,将值大的元素交换至右端,类似于一个气泡,不断的移动。
时间复杂度:O(n*n)
二、Java代码实现
package com.example.demo.dataStructure.sort;
/**
* 冒泡排序-常规写法
*/
public class BubbleSort {
public static void bubbleSort(int[] arg) {
for (int i = 0; i < arg.length; i++) {
for (int j = 0; j < arg.length - i - 1; j++) {
if (arg[j] > arg[j + 1]) {
int temp = arg[j];
arg[j] = arg[j + 1];
arg[j + 1] = temp;
}
}
}
}
public static void main(String[] args) {
int[] arg = { 9, 8, 7, 6, 5, 4, 3, 2, 1 };
bubbleSort(arg);
for (int i = 0; i < arg.length; i++) {
System.out.print(arg[i]);
}
}
}
运行结果如下:
123456789
三、优化思考
上面我们给出的数组是一个逆序,那如果我们给出的数组是一个顺序呢,即本来就是有顺序的,是不是也要每次都遍历这么多下呢?再或者我们给出的是一个部分有序的数组呢?
我们先优化外层循环:
// 优化外层循环
public static void bubbleSort2(int[] arg) {
for (int i = 0; i < arg.length;i++) {
boolean isSorted = true; // 增加一个标志位,每趟都初始化
for (int j = 0; j < arg.length - i - 1; j++) {
if (arg[j] > arg[j + 1]) {
int temp = arg[j];
arg[j] = arg[j + 1];
arg[j + 1] = temp;
isSorted = false; // 若有交换,则更改标志
}
}
if (isSorted) { // 根据标志判断是否有交换
break;
}
}
}
我们还可以优化内层循环:
// 优化内层循环
public static void bubbleSort3(int[] arg) {
int k = arg.length, pos = 0; // 初始化内层循环的次数,临时位置变量
for (int i = 0; i < arg.length;i++) {
boolean isSorted = true;
for (int j = 0; j < k - i - 1; j++) {
if (arg[j] > arg[j + 1]) {
int temp = arg[j];
arg[j] = arg[j + 1];
arg[j + 1] = temp;
isSorted = false;
pos = j; // 每趟比较中,若有交换,记录下位置
}
}
k = pos; // 将位置赋给内层循环的次数
if (isSorted) {
break;
}
}
}
猜你喜欢
- 2024-09-25 冒泡排序简单介绍(冒泡排序的一些简单例题)
- 2024-09-25 数据结构与算法-排序(一)冒泡排序
- 2024-09-25 冒泡排序法(冒泡排序法java代码)
- 2024-09-25 JAVA的一维数组和冒泡排序的详解(java对数组中的元素进行冒泡排序从小到大)
- 2024-09-25 排序算法整合(冒泡,快速,希尔,拓扑,归并)
- 2024-09-25 冒泡排序这个要单独说下(冒泡排序的用法)
- 2024-09-25 冒泡排序(Bubble Sort)的学习(冒泡排序方法详解)
- 2024-09-25 冒泡排序(Bubble Sort)是一种简单的排序算法...
- 2024-09-25 算法篇:Java实现九种排序算法6:交换排序之冒泡排序
- 2024-09-25 「算法」冒泡排序图文讲解(冒泡排序算法的基本思路)
欢迎 你 发表评论:
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)

本文暂时没有评论,来添加一个吧(●'◡'●)