冒泡排序(java实现并进行优化)

目录

1.1 基本介绍

1.2 演示冒泡过程

1.3 实现代码

1.4 优化

1.5 优化后的实现代码


1.1 基本介绍

冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就象水底下的气泡一样逐渐向上冒。

1.2 演示冒泡过程

小结上面的图解过程:
(1) 一共进行 数组的大小-1 次 外面的循环
(2)每一趟排序的次数在逐渐的减少 

1.3 实现代码

import java.util.Arrays;

public class BubbleSort {
	public static void main(String[] args) {
		int[] array = {5,8,1,-1,2};
		BubbleSort bSort = new BubbleSort();
		bSort.bubbleSort(array);
		System.out.println(Arrays.toString(array));
	}
	public void bubbleSort(int[] array) {
		for (int i = 0; i < array.length - 1; i++) {
			for (int j = 0; j < array.length - 1 - i; j++) {
				if (array[j] > array[j+1]) {
					int temp = array[j+1];
					array[j+1] = array[j];
					array[j] = temp;
				}
			}
		}
	}
}

测试结果

[-1, 1, 2, 5, 8]

1.4 优化

(1)因为排序的过程中,各元素不断接近自己的位置,如果一趟比较下来没有进行过交换,就说明序列有序,因此要在排序过程中设置一个标志 flag 判断元素是否进行过交换。从而减少不必要的比较。

(2)还可以把array.length - 1提到初始化模块中去,没必要每次循环都求一次。

(3)还可以把临时变量(temp)放在初始化模块中去,没必要每次循环都声明一次。

(4)交换还可以使用 ^ (异或)进行交换,这样交换更快,我测试8万个数据比不优化前(15秒左右)快5秒左右(仅在本人电脑是这样)。(这种方法适用于整型数据类型,不需要临时变量)。

1.5 优化后的实现代码

import java.util.Arrays;

public class BubbleSort {
	public static void main(String[] args) {
		int[] array = {5,8,1,-1,2};
		BubbleSort bSort = new BubbleSort();
		bSort.bubbleSort(array);
		System.out.println(Arrays.toString(array));
	}
	public void bubbleSort(int[] array) {
		for (int i = 0,m = array.length - 1; i < m; i++) {
			boolean falg = false;
			for (int j = 0,n = m - i; j < n; j++) {
				if (array[j] > array[j+1]) {
					falg = true;
					array[j+1] ^= array[j];
					array[j] ^= array[j+1];
					array[j+1] ^= array[j];
				}
			}
			if (!falg) {
				break;
			}
		}
	}
}

测试结果

[-1, 1, 2, 5, 8]

最后欢迎各位评论留言讨论,如有发现错误和不足的地方请各位大佬指出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值