算法_桶排序(java)

简介: 算法_桶排序(java)

前言

流程图:

9bcd258f7f3148f3909de1a85313ebfc.png


一、桶排序思想步骤

桶排序:将一组数分成若干份,然后利用数求出每份之间的范围差,然后将在符合范围的数进行插入,因为存在不断地插入数,所以可以使用LinkList和ArrayList链表来进行对桶数的存储和桶内数的存储。


过程:首先找出数中的最大值和最小值,然后求出桶数和间隔数,之后创建链表将桶数存入,将数中的每个数存入到对应的桶内,对每个桶内进行排序,从0号桶开始,将每个桶内排好顺序的数放入到一个新的数组中,最后打印数组即可


桶数计算:(max-min)/数组长度+1

间隔数:(max-min+1)/数组长度


二、代码

代码如下(示例):

void Bucketsort(int a[])
  {
    int max =a[0];
    int min =a[0];
    for(int i =0;i<a.length;i++) //求出最大最小值
    {
      if(a[i]<min)
      {
        min = a[i];
      }
      if(a[i]>max)  
      {
        max = a[i];
      }
    }
    //也可以这样写
  /*  
    int max1 = Integer.MAX_VALUE;
    int min1 = Integer.MIN_VALUE;
    for(int i =0;i<a.length;i++)
    {
      max1 = Math.max(max1, a[i]);
      min1 = Math.min(min1, a[i]);
    }
  */
    //计算桶的数量
    int bucketnum = (max-min)/a.length+1;
    int m = (max-min+1)/a.length;//间隔
    ArrayList<ArrayList<Integer>> bucket =new ArrayList<ArrayList<Integer>>(bucketnum);
    //将每个桶放入到链表中,因为不断插入,所以使用ArrayList
    for(int i=0;i<bucketnum;i++)
    {
      bucket.add(new ArrayList<Integer>());
    }
    //将每个元素放入桶中
    for(int i=0;i<a.length;i++)
    {
      int num = (a[i]-min)/m;
      bucket.get(num).add(a[i]);
    }
    //对每个桶进行排序
    for(int i=0;i<bucket.size();i++)
    {
      Collections.sort(bucket.get(i));
    }
    //将桶中的数赋值到原序列
    int index =0;
    for(int i =0;i<bucket.size();i++)
    {
      for(int j =0;j<bucket.get(i).size();j++)
      {
        a[index++] = bucket.get(i).get(j);
      }
    }

如文章存在错误,请在评论区指出,谢谢观看!

相关文章
|
5天前
|
监控 算法 网络协议
Java 实现局域网电脑屏幕监控算法揭秘
在数字化办公环境中,局域网电脑屏幕监控至关重要。本文介绍用Java实现这一功能的算法,涵盖图像采集、数据传输和监控端显示三个关键环节。通过Java的AWT/Swing库和Robot类抓取屏幕图像,使用Socket进行TCP/IP通信传输图像数据,并利用ImageIO类在监控端展示图像。整个过程确保高效、实时和准确,为提升数字化管理提供了技术基础。
36 15
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
101 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
5月前
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
11天前
|
缓存 算法 搜索推荐
Java中的算法优化与复杂度分析
在Java开发中,理解和优化算法的时间复杂度和空间复杂度是提升程序性能的关键。通过合理选择数据结构、避免重复计算、应用分治法等策略,可以显著提高算法效率。在实际开发中,应该根据具体需求和场景,选择合适的优化方法,从而编写出高效、可靠的代码。
25 6
|
5月前
|
搜索推荐 算法 Java
手写快排:教你用Java写出高效排序算法!
快速排序(QuickSort)是经典的排序算法之一,基于分治思想,平均时间复杂度为O(n log n),广泛应用于各种场合。在这篇文章中,我们将手写一个Java版本的快速排序,从基础实现到优化策略,并逐步解析代码背后的逻辑。
191 1
|
3月前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
161 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
3月前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
98 2
|
3月前
|
搜索推荐 Java Go
探究桶排序算法
探究桶排序算法
36 1
|
3月前
|
数据可视化 搜索推荐 Python
Leecode 刷题笔记之可视化六大排序算法:冒泡、快速、归并、插入、选择、桶排序
这篇文章是关于LeetCode刷题笔记,主要介绍了六大排序算法(冒泡、快速、归并、插入、选择、桶排序)的Python实现及其可视化过程。
25 0
|
3月前
|
算法 Java Linux
java制作海报一:java使用Graphics2D 在图片上写字,文字换行算法详解
这篇文章介绍了如何在Java中使用Graphics2D在图片上绘制文字,并实现自动换行的功能。
166 0

热门文章

最新文章