排序--计数排序

一,引言

计数排序是一种针对整数数据的高效排序算法。其主要流程可分为三个步骤:首先计算整数数据的数值范围;接着按大小顺序统计各数值的出现次数;最后根据统计结果输出排序后的数据序列。

二,求最值

遍历现有数据,获取最大值和最小值。通过计算两者差值确定数据区间范围,据此确定统计次数数组的分配空间大小。举个例子:

经过遍历得到最小值为1,最大值为9。用最大值减去最小值再加1,可得出数据范围为1到9,共包含9个不同数值。因此需要分配能存储9个整型数据的空间。代码如下:

cpp 复制代码
void sort(int* arr, int n)
{
	int min = arr[0];
	int max = arr[0];
	for (int i = 1; i < n; i++)
	{
		if (arr[i] < min)
		{
			min = arr[i];
		}
		if (arr[i] > max)
		{
			max = arr[i];
		}
	}
	int* p = (int*)calloc((max - min + 1), sizeof(int));
}

三,统计次数

遍历原数组时,先用最小值调整每个元素,将其转换为计数数组的索引位置。随后在计数数组对应的索引位置进行累加操作。完成所有元素的遍历后,即可生成最终的计数数组。举个例子:

每一次箭头的指向代表进行一次加加操作。代码实现:

cpp 复制代码
for (int i = 0; i < n; i++)
	{
		p[a[i] - min]++;
	}

四,排序

统计数组的每一个数据加上min就得出原数组的值。统计数组的顺序就是原数组排序后的相对位置。举个例子:

代码实现:

cpp 复制代码
int j = 0;
	for (int i = 0; i < (max-min+1); i++)
	{
		while (j[i]--)
		{
			a[j++] = i + min;
		}
	}

五,总结

计数排序的时间复杂度为ON远远小于一般排序,且该排序为稳定排序。但是计数排序要求输入数据必须是确定范围的整数。浮点数或字符串等数据类型无法直接使用该算法。当数据范围k远大于元素数量n时,需消耗O(k)额外空间存储计数数组。若k过大(如排序少量超大整数),会造成显著的空间浪费。对于动态范围或未知范围的数据,需先遍历确定范围值,增加预处理开销。此过程可能影响整体效率。

相关推荐
专注API从业者14 分钟前
用 Open Claw + 淘宝商品接口,快速实现电商商品监控与智能选品(附完整代码)
大数据·前端·数据结构·数据库
♡すぎ♡16 分钟前
ShaderLab:PBR+IBL(ShaderToy Translation)
算法·计算机图形学·着色器·pbr·ibl
Shadow(⊙o⊙)18 分钟前
前缀和:和可被K整除的子数组(normal)
数据结构·c++·算法
世纪末的小黑22 分钟前
【LeetCode自用】LeetCode自用记录贴,题目一:两数之和
数据结构·算法·leetcode
兰令水22 分钟前
topcode【随机算法题】【2026.5.22打卡-java版本】
java·算法·leetcode
努力努力再努力wz29 分钟前
【Redis入门系列】:Redis 内部编码机制与 String 深度解析:SDS 底层实现、三种编码与核心命令详解
c语言·开发语言·数据结构·数据库·c++·redis·缓存
Brilliantwxx31 分钟前
【C++】 认识STL set与map(基础接口+题目OJ运用)
开发语言·数据结构·c++·笔记·算法
05候补工程师33 分钟前
【线性代数】核心考点复习笔记:二次型配方法、施密特正交化步骤与特征值经典题型详解
经验分享·笔记·线性代数·考研·算法
Deep-w36 分钟前
【MATLAB】基于遗传算法的直流电机 PI 控制器参数优化研究
开发语言·算法·matlab
海清河晏11139 分钟前
数据结构 | 循环队列
数据结构·c++·visual studio