排序算法——桶排序

桶排序:

有点类似分块的做法

1.初始化桶:根据数据量来确定桶的数量与范围

2.为各个桶分配元素(O(n))

3.桶内元素排序(需要使用别的排序算法)

4.合并桶(O(k) k是桶的数量)

总的时间复杂度主要取决于桶内元素排序花费的时间,在最优情况下可以达到O(n+k),适用于数据分布均匀的情况下使用,不然容易变成普通快排一样大量数据堆积到一个桶内降低效率

java 复制代码
int size;//每个桶放的数据的范围
int cnt;//桶的个数
int minNum, maxNum;//arr数组的最大与最小值

public void bucketSort(int[] arr) {
	int minNum = arr.min();//简略写
	int maxNum = arr.max();
	int range = maxNum - minNum + 1;//总数据范围
	int size = range / arr.length() + 1;//桶的大小,即每个桶最多能存放的元素
	int count = range / size + 1;//桶的个数;至少要有一个桶所以要+1
	
	ArrayList<Integer>[] bucket = new ArrayList[];//初始化桶
	
	for(int i = 0; i < cnt; i++) bucket[i] = new ArrayList<>();//声明空间
/**
Eg: 对于arr = {1 2 5 8 9 11}为例 min = 1, max = 11, range = 10;
	可以求得size = 2, count = 6;
	每个桶的数据范围如下(左闭右开)
	0        				1     			  		2     				  3    	   4  	   5
	min+size*0--min+size*1  min+size*1--min+size*2  min+size*2--min+size*3 .............
	所以对于一个数num我们可以很容易判断它应该存到哪个桶中index = (num - min) / size
*/	
	for(int num : arr) {
		int index = (num - min) / size;//要放在哪个桶
		//可以使用插入排序  这里直接添加了
		bucket[index].add(num);
	}
	
	//也可先一股脑放入桶待全部数放完后对每个桶使用快排

	//排序完后合并桶
	int cnt = 0;
	for(int i = 0; i < count; i++) {//遍历桶
		for(int j = 0; j < bucket[i].length(); j++) {
			arr[cnt++] = bucket[i].get(j);
		}
	}
}
相关推荐
广师大-Wzx3 分钟前
JavaWeb:前端部分
java·前端·javascript·css·vue.js·前端框架·html
生万千欢喜心4 分钟前
Linux 安装金蝶天燕中间件 AAS-V9.0.zip
java·linux
WolfGang00732114 分钟前
代码随想录算法训练营 Day37 | 动态规划 part10
算法·动态规划
baizhigangqw17 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二)
算法·启发式算法·web app
alphaTao17 分钟前
LeetCode 每日一题 2026/4/13-2026/4/19
算法·leetcode·职场和发展
海兰19 分钟前
【第2篇-续】从零开始helloworld使用openAI通用模型的完整实现示例附源代码
java·人工智能·spring boot·alibaba·spring ai
ooseabiscuit20 分钟前
记录 idea 启动 tomcat 控制台输出乱码问题解决
java·tomcat·intellij-idea
执笔画流年呀21 分钟前
多线程及其特性
java·服务器·开发语言
灵智实验室22 分钟前
PX4姿态解算技术详解(四):姿态更新/递推与共锥补偿
算法·无人机·px 4
良木生香22 分钟前
【C++初阶】C++编程基石:编码表&&STL的入门指南
c语言·开发语言·数据结构·c++·算法