冒泡排序(Bubblesort)之Java实现
2013-12-12 10:32
253 查看
目录(?)[+]
冒泡排序算法介绍
冒泡排序比插入排序更简单,把最大的元素逐步推到最高位(当前须处理子数组的最高位)。依我的理解,冒泡排序是一个一层层筑顶的过程。顶筑好了,排序也就好了。冒泡排序的最坏运行时间是O(n2),效率和插入排序一样。冒泡排序算法Java实现
如《插入排序(Insertsort)之Java实现》一样,先实现一个数组工具类。代码如下:[java]
view plaincopy
public class ArrayUtils {
public static void printArray(int[] array) {
System.out.print("{");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]);
if (i < array.length - 1) {
System.out.print(", ");
}
}
System.out.println("}");
}
public static void exchangeElements(int[] array, int index1, int index2) {
int temp = array[index1];
array[index1] = array[index2];
array[index2] = temp;
}
}
逐步选取n-1到1(Java里面数组以0开始标记),分别作为第n,n-1,...,2层顶,第2层顶筑好了之后,只剩下一个比它小的元素,排序结束。每个顶的筑成都从位置0开始,依次和下一位置的元素比较,如果比下一位大,就交换它俩的位置。冒泡排序的Java实现以及测试代码如下:
[java]
view plaincopy
public class BubbleSort {
public static void main(String[] args) {
int[] array = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, -1, -2, -3 };
System.out.println("Before sort:");
ArrayUtils.printArray(array);
bubbleSort(array);
System.out.println("After sort:");
ArrayUtils.printArray(array);
}
public static void bubbleSort(int[] array) {
if (array.length <= 1) {
return;
}
int size = array.length;
for (int i = size - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
if (array[j] > array[j + 1]) {
ArrayUtils.exchangeElements(array, j, j + 1);
}
}
}
}
}
相关文章推荐
- 冒泡排序(Bubblesort)之Java实现
- 数据算法之冒泡排序(bubbleSort)的Java实现
- 数据算法之冒泡排序(bubbleSort)的Java实现
- 冒泡排序(Bubblesort)之Java实现
- 冒泡排序及C++/java代码实现(BubbleSort)
- 【Java SE】如何用Java实现冒泡排序
- Java实现冒泡排序
- java实现冒泡排序
- Java实现冒泡排序
- java实现冒泡排序
- 程序员必知的8大排序(三)-------冒泡排序,快速排序(java实现)
- 一个简单的冒泡排序和快速排序算法java实现
- 冒泡排序Java实现
- [java]冒泡排序的常规、改进以及递归实现
- 冒泡排序的Java实现
- 用java实现冒泡排序
- java 实现 冒泡排序、选择排序、插入排序。
- 用Java实现 ,冒泡排序与普通排序的区别
- java 实现冒泡排序
- 【Java】数组的冒泡排序和选择排序(原理+代码实现)