冒泡排序----深刻理解版本

前面虽然向大家介绍了冒泡排序,但是表达的不是很清楚,这次我带着更深刻的理解向大家介绍以下冒泡排序。

1.冒泡排序

冒泡排序其实是一种排序算法,通过数据之间的相互比较将一堆混乱的数据按照升序或者降序的顺序排列。

2.解题思路

解题思路依然不变,我们首先确立要比较的趟数,和一趟要比较的次数。

d46b094ca2e942bca08400760ab77b39.png

第一趟比较(红色部分)

76da688f65dc454c86e92443337bb85c.png

第二趟比较(绿色部分)

8c8e1e5abb4f4a9c8747caef26d9595b.png

第三趟比较(蓝色部分)

5f1ba9f5a4f54dedac48ba90e010b3e7.png

第四趟比较

11a3218ba26b4b218b6bdf6ea53a78f6.png

如上图所示,假设我们有五个数据要进行排序,我们要进行4趟排序,第一趟排序要进行比较4次,第二趟排序要比较3次,第三趟排序要比较2次,第四趟排序要进行比较1次。

所以我么得出结论:n个数据要进行排序时,要进行n-1趟排序。这里的趟数也是已经排序好数据的个数。 

代码实现

public class MySort {
    public static void Bubble(int[] arr){
        //确立趟数
        int i=0;
        for(i=0;i< arr.length-1;i++){
            //一趟要比较的次数
            for(int j=0;j< arr.length-1-i;j++){
                if(arr[j]>arr[j+1]){
                    int tmp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=tmp;
                }
            }
        }
    }
    public static void main(String[] args) {
        int[] arr=new int[]{10,8,6,9,3};
        System.out.print("排序前:");
        for(int j:arr){
            System.out.print(j+" ");
        }
        System.out.println();
        Bubble(arr);
        System.out.print("排序后:");
        for(int x:arr){
            System.out.print(x+" ");
        }
    }
}

这里我要介绍以下我更加深刻理解冒泡排序的一点,就是第二个for循环确定一趟要比较的次数,

其实上面是一种已经优化的版本了,未优化的版本循环条件为 j<arr.length-1在这种情况下,就意味着我们不论是进行哪一趟排序,在这一趟排序循环里面,它都会和所有的数据进行比较。不管之前经过排序就已经排序好的数据。

当我们写成 j<arr.length-1-i时,这里的i代表第几趟排序,经过i趟排序,就表示原本的数据中已经有i个数据已经排序好了,也就是说i也代表排序好的数据接着我们进行下一趟排序时,这一趟要排序的数据就不会和已经排序好的数据进行比较了,这要就提高的效率。

运行代码,如下图所示

3718e75557bb492cac28a4a543aa0897.png

但这还不是更好的优化版本。

先假设我们一开始的数据为10  3  6  8  9。

这时我们只进行一次比较就已经将数据排序好了,但是按照上面的写法,后面还是会进行后面比较的趟数,所以我们可以设计一个标志来确定在某一趟排序的时候,数据是否已经完全排序好了。

优化代码实现

public class MySort {
    public static void Bubble(int[] arr){
        //确立趟数
        int i=0;
        for(i=0;i< arr.length-1;i++){
            boolean flag=true;//标记
            //一趟要比较的次数
            for(int j=0;j< arr.length-1-i;j++){
                if(arr[j]>arr[j+1]){
                    int tmp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=tmp;
                    flag=false;
                }
            }
            if(flag==true){
                break;
            }
        }
    }
    public static void main(String[] args) {
        int[] arr=new int[]{10,8,6,9,3};
        System.out.print("排序前:");
        for(int j:arr){
            System.out.print(j+" ");
        }
        System.out.println();
        Bubble(arr);
        System.out.print("排序后:");
        for(int x:arr){
            System.out.print(x+" ");
        }
    }
}

我们设置了一个flag变量,一开始为true,如果有 没排序好的数据就会进入循环,将flag的值变为false,进行完这一趟的排序,就又进行下一趟排序,然后在来确定有无 没排序好的数据,如果没有,就不会进入第二个循环,最终flag的值为true。这时我们根据flag的值为true,就知道此时数据已经完全排序好了。 

  • 18
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
冒泡排序是一种简单直观的排序算法,其基本思想是通过相邻元素之间的比较和交换,将最大的元素逐渐移动到最后的位置。 具体而言,冒泡排序的过程如下: 1. 首先,我们从序列的第一个元素开始,比较其与后续的元素大小; 2. 若第一个元素大于后续元素,则交换两者的位置; 3. 依次比较第二个元素和第三个元素,直到序列的倒数第二个元素; 4. 经过第一轮的比较,最大的元素已经移到了最后的位置; 5. 接下来,我们继续进行第二轮的比较,此时我们只需要比较序列中前n-1个元素,因为最后一个元素已经是最大的; 6. 经过n-1轮的比较和交换,最终序列就按照从小到大的顺序排列好了。 冒泡排序的时间复杂度为O(n^2),其中n为序列的长度。这是因为冒泡排序的每一轮都需要比较n-1次,并且总共需要执行n-1轮。 尽管冒泡排序的时间复杂度较高,但它的实现非常简单,且空间复杂度较低,只需要一个额外的存储空间来交换元素的位置。因此,在一些元素个数较少或者序列基本有序的情况下,冒泡排序仍然是一个不错的选择。 值得注意的是,冒泡排序是一种稳定的排序算法,即相等的元素在排序后的相对位置不会改变。这一点对一些特定需求的排序问题可能是非常重要的。 总之,冒泡排序是一种简单但效率不高的排序算法,适用于一些小规模且简单的排序问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值