冒泡排序超详细解析

冒泡排序:

这个名字起的十分形象,当你完全理解后,你就会发现它为什么叫冒泡排序了。

首先,我们用一个简单的数组来开始剖析这个问题
例如我们的数组是这样的
在这里插入图片描述
我们第一趟从数组第一个来开始比较
在这里插入图片描述
第一个数和第二个数比较,谁小谁就在前面,这里发现3 比 7 小,如此的话,我们不用进行互换的操作了
再从第二个数字7开始与后一个比较
在这里插入图片描述

这里发现- 1 比7 小,互换
在这里插入图片描述
再继续如此的过程,直到全部比较完成,如此过后你会发现,最后一个数字,它是最大值。为什么会这样呢?

原因是,我们一轮的过程中,越小的在越前面,每次比较,都把小的放在前面了,那么循环遍历过后,你会发现,最大的会在数组的最后

如果你觉得还是比较难懂,我们可以换一个数组,更为明显
在这里插入图片描述
我们循环遍历过后,数组会变成这样
在这里插入图片描述
从此你大概能懂为什么它叫冒泡排序吧

它就像泡泡一样。

当你懂得以上冒泡排序的核心的时候,接下来,你就可以,编写代码了。

在这里我们要考量1个问题

问题是:我们该循环多少次?

同样我们也举一个很简单的列子来模拟这个过程

数组为 5 4 3 2 1
循环
第一次: 4 3 2 1 5
第二次: 3 2 1 4 5
第三次: 2 1 3 4 5
第四次: 1 2 3 4 5
从这个例子我们可以知道,我们只用循环 4 次就可以得到排好序的数组了。
至于为什么是4次,我们可以换个角度想想,
第一次 5是排好序的。
第二次 5和4是排好序的
以此类推,到2 3 4 5这些都是排好序的时候,1必定也是排好序的

从中我们也可以发现,其实每次我们做排序的过程可以少比较,之前排好序的数,这里用加粗来表示排好序
第一次: 4 3 2 1 5
第二次: 3 2 1 4 5
第三次: 2 1 3 4 5
第四次: 1 2 3 4 5

从此,我们就可以开始写代码了

 public static void sorted(int[] data) {
        //外面一层循环是次数
        int temp = 0;
        for(int i = 0; i < data.length - 1; i++) {
            //里面一层循环是沉底
            for(int j = 1; j < data.length - i; j++) {
                if(data[j - 1] > data[j]) {
                    temp = data[j - 1];
                    data[j - 1] = data[j];
                    data[j] = temp;
                }
            }
        }
    }

浅谈
学习算法,永远是,明白其中的核心,而不只是写代码,你看了我的解析过后,你可以自己编写代码,而不是看了我的代码,之后才写出来,这不是你自己的东西,这才是检验,你到底学没学会,如果你还觉得掌握的不是很踏实,就去刷刷相关的题目,这样一来,才是积累的过程

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

憨憨小江

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值