【算法 -桶排序】

定义

桶排序是一种基于分布的排序算法,它将数据分到有限数量的桶里,每个桶再分别进行排序,最后将所有桶中的数据合并成一个有序的结果。桶排序特别适合于数据分布较均匀的场景。

工作原理

  1. 创建桶:根据待排序数组的范围,将数据划分成多个桶。每个桶可以视为一个容器,用于存放属于该桶范围内的元素。
  2. 分配元素:将待排序的元素分配到相应的桶中。
  3. 排序桶内元素:对每个非空桶中的元素进行排序,常用的排序算法包括快速排序、归并排序或插入排序。
  4. 合并桶:将所有排序后的桶中的元素依次合并,形成最终的有序数组。

代码

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class BucketSort {

    public static void bucketSort(float[] arr) {
        // 1. 创建桶
        int n = arr.length;
        if (n <= 0) return;

        List<List<Float>> buckets = new ArrayList<>(n);
        for (int i = 0; i < n; i++) {
            buckets.add(new ArrayList<>());
        }

        // 2. 将元素分配到桶中
        for (float value : arr) {
            int bucketIndex = (int) (value * n); // 假设数据在 [0, 1) 范围内
            buckets.get(bucketIndex).add(value);
        }

        // 3. 对每个桶进行排序并合并
        int index = 0;
        for (List<Float> bucket : buckets) {
            Collections.sort(bucket); // 使用快速排序
            for (float value : bucket) {
                arr[index++] = value;
            }
        }
    }

    public static void main(String[] args) {
        float[] arr = {0.42f, 0.32f, 0.23f, 0.45f, 0.12f, 0.33f};
        bucketSort(arr);
        for (float value : arr) {
            System.out.print(value + " ");
        }
    }
}

时间复杂度

  • 最优情况:O(n + k),其中 n 是待排序元素的个数,k 是桶的数量。
  • 平均情况:O(n + k)。
  • 最坏情况:O(n^2),当所有元素落在同一个桶中并使用不够好的排序算法时。

空间复杂度

桶排序的空间复杂度为 O(n + k),需要额外的空间来存储桶。

优点

  • 适用于范围小且均匀分布的数据:在这种情况下,桶排序能高效地工作。
  • 稳定性:如果桶内排序算法是稳定的,那么桶排序也是稳定的。

缺点

  • 对桶的选择和数量敏感:不当的桶数量和范围选择会影响排序性能。
  • 空间消耗:需要额外的存储空间用于桶。

使用场景

  • 当待排序数据的范围已知并且分布较均匀时,如浮点数排序。
  • 对于一些特殊应用,如排序多个小范围的数值,例如图像处理中的颜色值排序。
相关推荐
颜淡慕潇几秒前
Redis 实现分布式锁:深入剖析与最佳实践(含Java实现)
java·redis·分布式
程序员秘密基地6 分钟前
基于vscode,idea,java,html,css,vue,echart,maven,springboot,mysql数据库,在线考试系统
java·vue.js·spring boot·spring·web app
何中应7 分钟前
【设计模式-5】设计模式的总结
java·后端·设计模式
草莓熊Lotso8 分钟前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM14 分钟前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法
吾日三省吾码25 分钟前
Spring 团队详解:AOT 缓存实践、JSpecify 空指针安全与支持策略升级
java·spring·缓存
CV点灯大师29 分钟前
C++算法训练营 Day10 栈与队列(1)
c++·redis·算法
风象南43 分钟前
SpringBoot的5种日志输出规范策略
java·spring boot·后端
GGBondlctrl1 小时前
【leetcode】递归,回溯思想 + 巧妙解法-解决“N皇后”,以及“解数独”题目
算法·leetcode·n皇后·有效的数独·解数独·映射思想·数学思想
咖啡啡不加糖1 小时前
深入理解MySQL死锁:从原理、案例到解决方案
java·数据库·mysql