桶排序

#include <iostream>
using namespace std;

void BucketSort(int *A, int Max, int Size) {
	int *B=new int [Max + 1];
	int i, j, count = 0;
	memset(B, 0, (Max + 1) * sizeof(int));
	for (i = 0; i < Size; i++) {
		j = A[i];
		B[j] += 1;
	}
	for (i = 0; i <= Max; i++) {
		if (B[i] > 0) {
			for (j = 0; j < B[i]; j++) {
				A[count] = i;
				count++;
			}
		}
	}
}
int main(int argc, const char * argv[])
{
	int A[] = { 1, 2, 2, 7, 4, 9, 3, 5 };
	int Max = 9; //这里可以用一个O(n)的函数来实现,假如数组的手动输入的,则在输入的时候就可以获取到。
	//这里直接赋值是为了排出别的因素,看着简单。
	int Size = sizeof(A) / sizeof(int);
	BucketSort(A, Max, Size);
	for (int i = 0; i < Size; i++) {
		printf("%d ", A[i]);
	}
	return 0;
}
posted @   如梦山河乀  阅读(94)  评论(0编辑  收藏  举报
编辑推荐:
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
阅读排行:
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(四):结合BotSharp
· Vite CVE-2025-30208 安全漏洞
· 《HelloGitHub》第 108 期
· MQ 如何保证数据一致性?
· 一个基于 .NET 开源免费的异地组网和内网穿透工具
点击右上角即可分享
微信分享提示