Java-死磕算法-排序-冒泡排序

本文详细介绍了冒泡排序算法的工作原理及其实现过程。通过对比相邻元素并交换位置的方式,逐步将数组中的最大值移至末尾,最终完成排序。文章还提供了一个具体的排序示例,帮助读者更好地理解冒泡排序的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

冒泡排序的思想是比较相邻的两个元素,将大的数据置换到右边,一直换到不能再换为止。



public void sort(int [] a){
        int temp=0;
        for(int i = a.length-1; i>0 ; --i){
              for(int j = 0 ; j<i;++j){
                if(a[j+1] < a[j]){
                         temp = a[j];
                         a[j]= a[j+1];
                         a[j+1] = temp;
          }
       }
    }
}

函数为外层循环为遍历次数–数组长度-1 , 内层循环为依次比较相邻的两个元素,如果左边的大就换到右边。具体举例如下:

有一个数组:
int a [] = new int []{6,4,9};
算法为:

4与6比,如果4小于6则4和6换位置。(a[1]和a[0]比,如果a[0]大就换位置)
第一轮换完之后为:4,6,9

6与9比,如果6大于9则6和9换位置。(a[2]和a[1]比,如果a[1]大就换位置)
第二轮不满足置换条件,过!

由此得:
第一次可以将最大值放到最后。
第二次把第二大的数放到-1位置。

所以,总比较轮数为数组长度-1次,

算法实现动画:http://download.youkuaiyun.com/detail/manhgj/5309704

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值