php中文网 | cnphp.com

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 555|回复: 0

冒泡排序的简单理解

[复制链接]

3153

主题

3163

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

UID
1
威望
0
积分
7984
贡献
0
注册时间
2021-4-14
最后登录
2024-11-25
在线时间
764 小时
QQ
发表于 2022-6-18 13:12:12 | 显示全部楼层 |阅读模式
详细描述
冒泡排序是一种交换排序,基本思想是在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。

即每当两个相邻的数比较后发现它们的顺序与排序要求相反时,就将它们互换。

冒泡排序详细的执行步骤如下:

从第一个元素开始,比较相邻的元素,如果前一个比后一个大,就交换它们两个;
从前往后,对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对,这样在最后的元素就会是最大的数;
将这次找出的最大元素放在最后一个元素位置上,然后针对除这个最大元素以外的其他所有元素重复以上 1~2 步骤;
重复以上步骤,直到最后第一个元素和第二个元素完成比较、交换,则排序完成。
算法图解
4e2e58e7be53a56db50880e775212940_1655515-20220618110030112-1036000663.gif
image.png
package cn.fatedeity.sort;

public class BubbleSort {
    private static void swap(int[] numbers, int src, int target) {
        int temp = numbers[src];
        numbers[src] = numbers[target];
        numbers[target] = temp;
    }

    public static int[] sort(int[] numbers) {
        for (int i = 0; i < numbers.length - 1; i++) {
            boolean doSwap = false;
            for (int j = 0; j + 1 < numbers.length - i; j++) {
                if (numbers[j] > numbers[j + 1]) {
                    swap(numbers, j, j + 1);
                    doSwap = true;
                }
            }
            // 优化基础冒泡排序的步骤
            if (!doSwap) {
                // 如果遍历整个序列无需交换,则表示整个序列已经完全有序
                return numbers;
            }
        }
        return numbers;
    }
}





上一篇:百家号跳转官网操作全解析(如何实现百家号内容留链接...
下一篇:一致性哈希的简单认识
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|php中文网 | cnphp.com ( 赣ICP备2021002321号-2 )

GMT+8, 2024-11-25 15:07 , Processed in 0.254005 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2020, Tencent Cloud.

申明:本站所有资源皆搜集自网络,相关版权归版权持有人所有,如有侵权,请电邮(fiorkn@foxmail.com)告之,本站会尽快删除。

快速回复 返回顶部 返回列表