桶排序(Java语言)

视频讲解地址:【手把手带你写十大排序】8.桶排序(Java语言)_哔哩哔哩_bilibili

代码:

java 复制代码
public class BucketSort {
    public void sortFunction(int[] array, int bucketNum) {
        int max = Integer.MIN_VALUE, min = Integer.MAX_VALUE;
        for (int i : array) {
            max = Math.max(max, i);
            min = Math.min(min, i);
        }
        List<List<Integer>> bucketList = new ArrayList<List<Integer>>();
        for (int i = 0; i < bucketNum; i++) {
            bucketList.add(new ArrayList<Integer>());
        }
        for (int i : array) {
            int bucketIndex = (i - min) * (bucketNum - 1) / (max - min);
            List<Integer> list = bucketList.get(bucketIndex);
            list.add(i);

        }
        for (int i = 0, arrIndex = 0; i < bucketList.size(); i++) {
            List<Integer> bucket = bucketList.get(i);
            Collections.sort(bucket);
            for (int num : bucket) {
                array[arrIndex++] = num;
            }
        }

    }
}
相关推荐
围炉聊科技4 分钟前
Vibe Kanban:Rust构建的AI编程代理编排平台
开发语言·rust·ai编程
2501_941802487 分钟前
从缓存更新到数据一致性的互联网工程语法实践与多语言探索
java·后端·spring
hqwest17 分钟前
码上通QT实战04--主窗体布局
开发语言·css·qt·布局·widget·layout·label
拆房老料19 分钟前
文档预览开源选型对比:BaseMetas FileView 与 KK FileView,谁更适合你的系统?
java·开源·java-rocketmq·开源软件
Frank_refuel21 分钟前
C++之内存管理
java·数据结构·c++
leiming621 分钟前
c++ qt开发第一天 hello world
开发语言·c++·qt
奋斗者1号27 分钟前
MQTT连接失败定位步骤
开发语言·机器学习·网络安全
钱多多_qdd28 分钟前
springboot注解(五)
java·spring boot·后端
2501_9418227533 分钟前
面向灰度发布与风险隔离的互联网系统演进策略与多语言工程实践分享方法论记录思考汇总稿件
android·java·人工智能
33三 三like35 分钟前
毕设任务分析
开发语言