百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT精选 > 正文

经典基础排序算法——桶排序(桶排序例子)

ccwork 2025-04-10 21:10 8 浏览

简介

十大经典排序算法里面冒泡、插入、选择排序时间为O($n^2$),归并、快排、堆排序这些排序时间为O(nlogn),此外还有三种更快的排序算法为桶排序,基数排序,计数排序。后面这三种排序时间为O(n),因此也被称之为线性排序算法。

桶排序一般是分这几步来操作:

  1. 先定义一组或者说几个有序的“桶”
  2. 使用映射函数将数组内的数据映射到各自对应的“桶”内
  3. 在每个“桶”内进行排序(归并、插入、快排等等都可以)
  4. 按顺序将每个”桶“内的数据依次取出,就可以输出一个有序的数组/数列

尝试实现

输入数组为:40,55,10,64,2,71,90,25,81,43

2.1 创建有序”桶“

”桶“一般我们采用二维的数组来实现。考虑到数组还要扩容,所以在Java端直接用ArrayList来做即可。

ArrayList<ArrayList> buckets = new ArrayList<>();

另外一个就是桶的个数。很多例子中都是给个默认大小5,开始时先遍历一遍数组,找出最大值和最小值。然后根据(max-min)/5 + 1来计算出桶的个数。我们这里做简化处理,因为知道输入数组元素值得范围大致为0到99,可以按0-9,10-19...90-99这样划分为10组,所以取桶的个数为10。

2.2 映射函数

这一步的映射函数的作用是根据数组中的元素值,计算出它应该被归类为哪个桶,也就是计算出桶的下标值。

上一步中知道是划分为10组,所以映射函数可以简单写为int index = item/10

2.3 桶内排序

桶内排序可以采用冒泡、插入等等算法来实现,我们也是简化处理直接调用系统API来实现```

2.4 整理数据

这一步最简单,按桶的编号从0到9将各自里面的数据拿出来回写到输入数组中即可。

代码实现

public static void bucketSort(int[] nums) {
    if (null == nums || 1 == nums.length) {
        return;
    }
    //第一步,创建桶
    ArrayList<ArrayList> buckets = new ArrayList<>();
    int bucketSize = 10;
    for(int i=0;i<bucketSize;i++){
        buckets.add(new ArrayList<>());
    }

    //第二步使用映射函数将数据分到各自的桶里面
    for (int i = 0; i < nums.length; i++) {
        int index = nums[i] / 10;
        buckets.get(index).add(nums[i]);
    }

    //第三步,将各个桶内的元素进行排序
    for (int i = 0; i < bucketSize; i++) {
        Collections.sort(buckets.get(i));
    }

    //第四步,按顺序将每个桶内的元素读取回写到nums中
    int index = 0;//回写时用的游标
    for (int i = 0; i < bucketSize; i++) {
        for (int j = 0; j < buckets.get(i).size(); j++) {
            nums[index++] = buckets.get(i).get(j);
        }
    }
}

算法分析

时间复杂度

假如要排序n个数字,桶的个数取m,每个桶里面元素个数为s=$n/m$。每个桶采用标准API进行排序(标准api的实现一般都是快排的改进版)排序时间复杂度为O(slogs)。换算一下就是O((n/m*m)logn/m)=O(nlogn/m)。理想状态下桶的个数m的值接近n的大小,logn/m可以看成是个常量。所以可以近似的认为桶排序的时间复杂度为O(n)。

最坏情况下,数据没有均匀的分布而是被集中到了一个桶里面,那桶排序的时间就会退化为O(nlogn)

空间复杂度

已上过程中我们知道桶排序是借助了若干个桶的空间来实现的,所以它的空间复杂度为O(m)。m为桶的个数。

稳定性

关于稳定性我们知道同一个算法由于我们不同的实现会导致它从一个稳定的排序算法变为不稳定的排序算法。

按桶排序的过程我们知道,相同大小的元素会按自己的原始顺序,先后落入相同编号的桶内。如果桶内排序采用的是稳定的排序算法,那么输出的顺序肯定和之前的一样不会发生变化。因此桶排序是个稳定的排序算法

备注

虽然桶排序的性能优异,但是并不能替代快排、归并等等这些算法。原因在于桶排序的特殊要求:1.它需要将待排序的元素均匀的划分到m个桶内;2.桶和桶之间是天然排好序的,这样各个桶内元素排好序后,桶和桶之间是不需要进行排序的。而大部分情况下,元素很难做到均匀分布到各个桶内。所以它有一个很明显的缺点,空间利用率低。

综上,桶排序一般适用于元素大小范围跨度不大,分布比较均匀的情况下。另外就是外排序,比如有十几个G这样的数据,一次性很难加载到内存中。比较适合采用桶排序。先对数据进行划分,然后每个小块加载到内存中进行排序,进而完成整体数据的排序操作。


这是我的公众号欢迎大家关注:


相关推荐

二十三、Java类与对象简介(java第十一章类和对象)

在Java编程语言中,类(Class)和对象(Object)是面向对象编程(OOP)的核心概念。描述类类是Java程序的基本组成单元,是对象的模板。类定义了对象的属性和方法。属性是对象的状态信息,而方...

设计模式-结构型-代理模式(proxy)

1.概念需要给对象提供一个代理以控制对该对象的访问,访问对象不适合或者不能直接引用目标对象,代理对象作为访问对象和目标对象之间的中介;根据代理类生成时机不同,分为静态代理和动态代理;静态代理代理类在编...

深度解析设计模式七大原则之——里氏替换原则

临近端午节,各位读者,你们假期行程安排好了吗?“菜鸟”已经做好决定了,谁都不能阻拦(产品经理也不行),“菜鸟”要好好在家休息三天。最近实在是太累了,一直在疯狂的加班。好了好了言归正传,开始我们的正文。...

Java代理模式详解:智能中介的编程艺术

一、生活场景中的代理思维想象您要租房子,但不想直接与房东打交道,这时房产中介就发挥作用了:1.中介帮您筛选房源(访问控制)2.签约前验证房东资质(预处理)3.协助办理合同手续(功能增强)4.处...

哪个创意最能打动你? 为你欣赏的“创意之星”投一票

这一期的《超级课堂·暑期特别活动》将评出5位“创意之星”,获得价值2000元的奖品。本期我们选登了部分中小学生在昙华林留下的创意作品,欢迎为最能打动你的作品投上一票。大众评审目前采取微信投票:扫描二维...

Netty基础—6.Netty实现RPC服务(netty reactor)

大纲1.RPC的相关概念2.RPC服务调用端动态代理实现3.Netty客户端之RPC远程调用过程分析4.RPC网络通信中的编码解码器5.Netty服务端之RPC服务提供端的处理6.RPC服务调用端实现...

静态代理和动态代理(静态代理和动态代理的优缺点)

1.什么是代理很多人肯定听过和看到过飞机票代理点,火车票代理点。那这些代理点干得事情就是帮航空公司,火车站出售火车票的工作。它们算是一个中间商。实际的服务不是由它们提供。而是由真正的服务商提供。通过这...

Java反射机制与Spring动态代理深度解析

一、Java反射机制原理剖析1.1反射的本质与实现基础Java反射(Reflection)是Java语言的核心特性,允许程序在运行时:动态加载类获取类结构元数据操作类属性和方法关键技术支撑:java...

Java 代理模式详解(java代理原理)

1.代理模式代理模式是一种比较好理解的设计模式。简单来说就是我们使用代理对象来代替对真实对象(realobject)的访问,这样就可以在不修改原目标对象的前提下,提供额外的功能操作,扩展目标对象...

SpringBoot全局异常处理:如何优雅应对多系统多格式错误响应需求

SpringBoot全局异常处理:如何优雅应对多系统多格式错误响应需求引言部分在微服务架构中,你是否曾为处理不同外部系统的异常响应而头痛?A系统要求返回JSON格式的:{code:1001,mes...

3分钟吃透代理技术!(代理一般都是怎么做)

最近有学员问了我一些问题,什么是代理,又该在什么地方使用。结合之前的讨论,这篇文章我们一起细致的讲解一下关于代理的一些问题。在Java中,代理通常分为两类:静态代理动态代理两者技术实现是不一样的,...

苏州网络维护 | 学习网络维护,从哪入手

我们想要学习网络维护,从哪入手呢?先带大家了解下网络维护1.培养基础知识:建立对计算机网络基本原理的理解。学习计算机网络的基础概念,如IP地址、子网掩码、路由器、交换机、协议等。2.学习网络技术:深入...

CAD如何快速一键编号?(cad如何一次性全部编号)

cad一键自动编号。·第一步,在命令行数abh空格。·第二步,打开自动编号对话框,选择用默认的图言编号,编号文字的高度根据图纸的大小设置零点八。当然如果图纸很大,设置比如十一百的有可能数字编号,这点很...

职场新人必知的10个高效工作法,助你快速升职加薪

初入职场,面对繁杂的工作任务和陌生的职场环境,如何才能快速适应并脱颖而出?以下是10个高效工作法,帮助职场新人提升工作效率,快速实现升职加薪的目标。---1.制定每日工作计划-推荐理由:每天开始...

《魔导英雄传说》新手攻略,快速升级,礼包码,最强阵容排列

《魔导英雄传说》新手攻略一、武将培养指南英雄选择与培养:英雄品质分为SSR、SR、A,优先培养SSR英雄,如张飞、孙尚香等核心英雄阵营搭配:同阵营上阵英雄越多,战力加成越高,建议优先培养同一阵营的英雄...