起泡/冒泡排序(Bubble Sort)- java实现

学习自严蔚敏、吴伟民的《数据结构》-清华大学出版

过程很简单,首先将第一个元素与第二个元素进行比较,若第一个元素比第二个元素大,则进行交换,然后比较第二个元素与第三个元素。依次类推,直至第n-1与第n个元素比较完,这样最大的元素会被交换到最后一个位置。上述过程为一趟排序,然后进行第二趟排序,直到第n-1个元素...

一般需要n-1趟比较,才可以将整个无序的数组排成有序状态,时间复杂度为O(n2)。

算法实现:

	public static int[] bubbleSort(int[] arr) {
		// 比较循环比数组长度小1,因为比较第二个时,已经和第一个进行过比较
		for (int i = 0; i < arr.length - 1; i++) {
			// -i的原因是,在这层循环比较完后,大的数已经放到后面,因此后面的不需要再比较
			for (int j = 0; j < arr.length - 1 - i; j++) {
				// 小心控制,避免下标越界
				if (arr[j] > arr[j + 1]) {
					int temp = arr[j];
					arr[j] = arr[j + 1];
					arr[j + 1] = temp;
				} // if
			} // for
		} // for
		return arr;
	}

以下参考自:https://blog.csdn.net/csdnsevenn/article/details/84452866

缺陷:

对于数组中元素已经排好序,由于没有遍历完循环,因此还会进入循环进行比较,白白浪费时间,为此,以下是对其的改进

public static int[] bubbleSort(int[] arr) {

    // 比较循环比数组长度小 1 ,因为比较第二个时,已经和第一个进行过比较
    for (int i = 0; i < arr.length - 1; i++) {
        
        // 在比较结束后,若没有元素移动,则说明数组已经有序了,故判断之后 break 即可
        boolean flag = false;

        // -i 的原因是,在这层循环比较完后,大的数已经放到后面,因此后面的不需要再比较
        for (int j = 0; j < arr.length - 1 - i; j++) {
        // 小心控制,避免下标越界
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;

                flag = true

            } // if
        } // for
        if (!flag) 
            return arr;
    } // for
    return arr;
}

 // 2020/5/31 补充

经过回顾,发现冒泡排序还有第三种优化方案,那就是对 数组的前面部分无序,后面部分已经有序的数组 而言,会多次比较后面部分有序的元素,造成浪费,因此在第二种的优化前提下,还可以定义一个变量:最后一次交换的位置,具体改进思路可参考:冒泡排序及其改进(转载自CSDN公众号)

public static int[] bubbleSort(int[] arr) {

    int lastExchangeIndex = arr.length - 1;

    // 比较循环比数组长度小 1 ,因为比较第二个时,已经和第一个进行过比较
    for (int i = 0; i < arr.length - 1; i++) {
        
        // 在比较结束后,若没有元素移动,则说明数组已经有序了,故判断之后 break 即可
        boolean flag = false;

        // -i 的原因是,在这层循环比较完后,大的数已经放到后面,因此后面的不需要再比较
        for (int j = 0; j < lastExchangeIndex; j++) {
        // 小心控制,避免下标越界
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;

                flag = true;

                lastExchangeIndex = j;

            } // if
        } // for

        if (!flag) 
            return arr;
    } // for
    return arr;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值