【数据结构与算法 01】冒泡排序

来源:互联网 发布:excel数据保护一列 编辑:程序博客网 时间:2024/05/17 06:32

算法思想:

  • 一共进行 array.size-1趟排序,每一趟排序,都将左右两个数进行比较大小,并且交换位置,这样的效果是:每一趟排序中,能找到最大的值冒泡到该趟排序的最后面,这样的话,第一趟排序,最后一个数是最大的,第二趟排序,倒数第二个数就是第二大的,最后一趟排序后 (因为最后一趟只有一个数,不用比较,所以比较次数是 array.size-1 趟),将得到有序数组

博客地址:http://blog.csdn.net/mkrcpp/article/details/39178213

import java.util.Arrays;/*** * @title 冒泡排序 * @author michael.mao * @date 2014年9月10日 上午10:00:44 * @version V1.0 */public class BubbleSort{/*** * @title 一共进行 array.size-1趟排序,每一趟排序,都将左右两个数进行比较大小,并且交换位置,这样的效果是:每一趟排序中, *        能找到最大的值冒泡到该趟排序的最后面,这样的话,第一趟排序,最后一个数是最大的,第二趟排序,倒数第二个数就是第二大的,最后一趟排序后 *        (因为最后一趟只有一个数,不用比较,所以比较次数是 array.size-1 趟),将得到有序数组 * @param array * @author michael.mao * @date 2014年9月10日 上午10:28:00 * @version V1.0 */public static void execute(int[] array){int tmp = 0;// 如果一次循环后发现没有交换,说明数组有序,无需排序boolean isSwap = true;for (int i = 0; ((i < array.length - 1) && isSwap); i++){isSwap = false;for (int j = 0; j < array.length - 1 - i; j++){if ( array[j] > array[j + 1] ){tmp = array[j + 1];array[j + 1] = array[j];array[j] = tmp;isSwap = true;}}}}// 循环测试次数public static int LOOP_COUNT = 100;public static int ARRAY_SIZE = 10000;public static void main(String[] args){int[] mArray = Common.getArray(ARRAY_SIZE);int allTime = 0;for (int i = 0; i < LOOP_COUNT; i++){// 拷贝数组int[] tmpArray = Arrays.copyOf(mArray, ARRAY_SIZE);long tmpTime = System.currentTimeMillis();execute(tmpArray);allTime += System.currentTimeMillis() - tmpTime;}System.err.println("数组大小为(" + ARRAY_SIZE + ")的" + LOOP_COUNT + "次冒泡排序的平均耗时为:" + allTime / (float) LOOP_COUNT);}}


数组大小为(10000)的100次冒泡排序的平均耗时为:125.79 ms





2 0