排序算法——桶排序

  • 把数据放进若干个桶,然后在桶里用其他排序,近乎分治思想。从数值的低位到高位依次排序,有几位就排序几次。例如二位数就排两次,三位数就排三次,依次按照个十百...的顺序来排序。

第一次排序:50 12 43 23 33 15 66 98 18 89

第二次排序:12 15 18 23 33 43 50 66 89 98

代码:

cpp 复制代码
//桶排序
void bucket_sort(int* a, int len){	
	int n = 1;
	int idx;
	int k;
	int* pTemp = NULL;
	while (n<AREA){//循环 log10AREA 次
		//1 做桶  并初始化桶
		pTemp = malloc(10 * len *sizeof(int));
#if 0
		for (int i = 0; i < 10; i++){
			for (int j = 0; j < len; j++){
				pTemp[i*len + j] = -1;
			}
		}
#else
		for (int i = 0; i < 10*len; i++){
			pTemp[i] = -1;
		}
#endif
		//2 根据特性(对应位作为桶的编号)放入桶中
		for (int i = 0; i < len; i++){
			//a[i]
			idx = a[i] / n % 10;//获取到数据这一轮要看的位上的数据

			pTemp[ idx*len + i] = a[i];
		}
		//3 从桶中取出,覆盖a数组
		k = 0;
		for (int i = 0; i < 10 * len; i++){
			if (pTemp[i] != -1)
				a[k++] = pTemp[i];
		}
		//4 销毁桶
		free(pTemp);
		pTemp = NULL;
		n *= 10;
	}
}
相关推荐
少许极端6 分钟前
算法奇妙屋(二十五)-递归问题
算法·递归·汉诺塔
Remember_99311 分钟前
【数据结构】初识 Java 集合框架:概念、价值与底层原理
java·c语言·开发语言·数据结构·c++·算法·游戏
:mnong14 分钟前
通过交互式的LLM算法可视化工具学习大语言模型原理
学习·算法·语言模型
郝学胜-神的一滴15 分钟前
QtOpenGL多线程渲染方案深度解析
c++·qt·unity·游戏引擎·godot·图形渲染·unreal engine
hqwest16 分钟前
码上通QT实战33--监控页面14-刻度盘旋转
开发语言·qt·qdial·qlcdnumber·modbus功能码06
栈低来信17 分钟前
klist链表
linux·数据结构·链表
源代码•宸18 分钟前
Golang原理剖析(channel源码分析)
开发语言·后端·golang·select·channel·hchan·sudog
liuyunshengsir19 分钟前
golang Gin 框架下的大数据量 CSV 流式下载
开发语言·golang·gin
BlockChain88820 分钟前
MPC 钱包实战(三):Rust MPC Node + Java 调度层 + ETH 实际转账(可运行)
java·开发语言·rust
吉吉6121 分钟前
在 Windows 和 Linux 的 VSCode 中配置 PHP Debug
开发语言·php