当前位置: 首页 > article >正文

排序算法之桶排序详细解读(附带Java代码解读)

桶排序(Bucket Sort)是一种基于分布的排序算法,它通过将待排序的数据分配到若干个桶(即子区间)中,然后对每个桶内的元素进行排序,最后将各个桶中的元素合并以得到最终的排序结果。桶排序适用于均匀分布的数据,对于特定的数据集可以达到线性时间复杂度。

算法思想

桶排序的基本思想是:

  1. 分桶:将待排序的元素分到若干个桶中。每个桶内的元素范围是相对狭窄的。
  2. 排序桶内元素:对每个桶内的元素进行排序,可以使用其他排序算法(如插入排序)进行排序。
  3. 合并桶:将所有桶中的元素按顺序合并,得到排序后的数组。

过程示例

假设有一个待排序的数组:[0.78, 0.17, 0.39, 0.26, 0.72, 0.94, 0.21, 0.12]

步骤 1: 分桶
  1. 设定桶的数量(例如 10 个桶,每个桶的范围为 0 到 1)。

  2. 根据数据的值将数据分配到相应的桶中:

    • 桶 1:[0.12, 0.17]
    • 桶 2:[0.21, 0.26, 0.39]
    • 桶 3:[0.72, 0.78]
    • 桶 4:[0.94]
步骤 2: 排序桶内元素
  1. 对每个桶内的元素进行排序:

    • 桶 1 排序后:[0.12, 0.17]
    • 桶 2 排序后:[0.21, 0.26, 0.39]
    • 桶 3 排序后:[0.72, 0.78]
    • 桶 4 排序后:[0.94]
步骤 3: 合并桶
  1. 将各个桶中的元素按顺序合并:

    • 最终排序结果:[0.12, 0.17, 0.21, 0.26, 0.39, 0.72, 0.78, 0.94]

算法复杂度

  • 时间复杂度:

    • 最坏情况: O(n^2)(当所有元素都落在一个桶中)
    • 平均情况: O(n + k)(k 是桶的数量)
    • 最佳情况: O(n + k)

    其中,n 是元素的数量,k 是桶的数量。

  • 空间复杂度: O(n + k) 需要额外的空间来存储桶和排序的结果。

优点

  1. 线性时间复杂度:在数据均匀分布的情况下,可以达到接近线性的时间复杂度。
  2. 适用于大数据集:特别适合处理数据范围较小的情况(如浮点数在 [0, 1] 之间)。

缺点

  1. 依赖数据分布:当数据分布不均匀时,桶排序的效率可能降低。
  2. 空间复杂度高:需要额外的桶来存储数据。

Java代码解读

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class BucketSort {

    // 主方法:执行桶排序
    public static void bucketSort(float[] arr) {
        int n = arr.length;

        // 1. 创建桶
        if (n <= 0) return;
        List<Float>[] buckets = new ArrayList[n];
        for (int i = 0; i < n; i++) {
            buckets[i] = new ArrayList<>();
        }

        // 2. 将元素分配到桶中
        for (float num : arr) {
            int index = (int) (num * n); // 桶的索引
            buckets[index].add(num);
        }

        // 3. 对每个桶内的元素进行排序
        for (int i = 0; i < n; i++) {
            Collections.sort(buckets[i]);
        }

        // 4. 合并所有桶中的元素
        int index = 0;
        for (int i = 0; i < n; i++) {
            for (float num : buckets[i]) {
                arr[index++] = num;
            }
        }
    }

    public static void main(String[] args) {
        float[] arr = {0.78f, 0.17f, 0.39f, 0.26f, 0.72f, 0.94f, 0.21f, 0.12f};
        System.out.println("排序前的数组:");
        for (float num : arr) {
            System.out.print(num + " ");
        }
        System.out.println();

        bucketSort(arr);

        System.out.println("排序后的数组:");
        for (float num : arr) {
            System.out.print(num + " ");
        }
    }
}

代码说明

  1. bucketSort方法:

    • bucketSort 方法创建了 n 个桶,将元素分配到相应的桶中。
    • 对每个桶内的元素进行排序,最后将所有桶中的元素按顺序合并。
  2. 分配到桶:

    • 使用 num * n 计算桶的索引,将每个元素分配到相应的桶中。
  3. 排序桶内元素:

    • 对每个桶使用 Collections.sort 进行排序,确保桶内元素有序。
  4. 合并桶:

    • 将各个桶中的元素按顺序合并到原数组中,得到排序后的结果。

http://www.kler.cn/news/285206.html

相关文章:

  • 模型 错位竞争(战略规划)
  • 从Vuex 到 Pinia,Vue 状态管理的进化
  • HTB-sequal(mysql)
  • 十一. 常用类
  • 如何开发针对不平衡分类的成本敏感神经网络 python
  • 遇到“Interpreter parsed an intent ‘xxx‘ which is not defined in the domain“报错
  • 贵州大数据实验室建设案例分享
  • vue调用booststrap弹窗
  • 大数据-112 Flink DataStreamAPI 程序输入源 DataSource 基于文件、集合、Kafka连接器
  • Linux随记(十一)
  • android 14及android15 READ_EXTERNAL_STORAGE跟相册,视频权限的适配
  • GraphRAG 文本分割优化
  • 深度学习100问31:如何降低语言模型的困惑度
  • yolov8旋转目标检测部署教程(附代码c++_python)
  • 在Java中,获取输入内容可以通过多种方式实现,以下是三种常用的方式:Scanner、BufferedReader 和 Console 的具体代码示例
  • chromedriver下载地址
  • c# net8调用vc写的dll
  • 机械学习—零基础学习日志(如何理解概率论10)
  • 学习记录:js算法(二十):子数组最大平均数 I、无重复字符的最长子串
  • Linux(文件的查找和解压缩)
  • RelativeLayout相对布局
  • 使用 UniApp 实现摄像头视频流的接入并在页面上显示视频流
  • NC115.栈和排序_C++题解
  • python-word添加标题,段落,文字块
  • Web开发 Ajax 2024/3/31
  • 004、架构_计算节点
  • 科研绘图系列:R语言单细胞差异基因四分图(Quad plot)
  • 加密与安全_前后端通过AES-CBC模式安全传输数据
  • 【Python】运行tcl、perl程序
  • EasyExcel冲突问题,java.lang.NosuchFieldError: Factory