计数排序详解

个人主页:Lei宝啊

愿所有美好如期而遇


前言

这种排序在部分情境下出奇地好,也是一种不错的排序

思路

有一个无序数组,我们从中找到最小和最大的数,最大的数减最小的数+1的大小就是我们将要新建数组的大小,这个新建数组的作用就是存储无序数组中每个数有多少个,然后我们通过新建数组从头到尾或从尾到头将值重新赋回原数组。

代码

需要提到的是我们在新建数组中将减去最小值统计,在往回赋值时再加上最小值。

复制代码
//计数排序
void CountSort(int* arr, int n)
{
	int min = arr[0];
	int max = arr[0];

	for(int i = 1; i < n; i++)
	{
		if (min > arr[i])
			min = arr[i];
			
		if (max < arr[i])
			max = arr[i];
	}

	int* temp = (int*)malloc(sizeof(int) * (max - min + 1));
	memset(temp, 0, sizeof(int) * (max - min + 1));

	for (int i = 0; i < n; i++)
	{
		temp[arr[i] - min]++;
	}

	int index = 0;
	for (int i = 0; i <= n; i++)
	{
		while (temp[i] != 0)
		{
			arr[index++] = i + min;
			temp[i]--;
		}
	}

	free(temp);
}

相关推荐
沐苏瑶2 分钟前
Java 数据结构精讲:二叉树遍历算法与底层实现剖析
数据结构·算法
董董灿是个攻城狮30 分钟前
大模型连载8:词向量如何表示近义词?
人工智能·python·算法·机器学习
Jasmine_llq34 分钟前
《B4001 [GESP202406 一级] 立方数》
算法·单输入处理·整数算术运算·立方数枚举验证算法(核心逻辑)·循环终止优化算法·状态标记算法·三元运算符输出
芸忻43 分钟前
day 13 第六章 二叉树 part01代码随想录算法训练营71期
数据结构·算法
2401_900151541 小时前
C++中的桥接模式
开发语言·c++·算法
小O的算法实验室1 小时前
2026年IEEE TNSE SCI2区,基于预测的双阶段分布式任务分配方法+搜救场景中最大化任务分配,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
月流霜1 小时前
Midjourney 零基础控图七大参数
人工智能·算法·midjourney
luckycoding1 小时前
1487. 保证文件名唯一
数据结构·算法·leetcode
DeeGLMath1 小时前
从基础算法到机器学习的研究轨迹
人工智能·算法·机器学习
Barkamin1 小时前
冒泡排序的简单实现
java·算法·排序算法