排序算法--------计数排序

作者前言

🎂 ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂

​🎂 作者介绍: 🎂🎂

🎂 🎉🎉🎉🎉🎉🎉🎉 🎂

🎂作者id:老秦包你会, 🎂

简单介绍:🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂

喜欢学习C语言和python等编程语言,是一位爱分享的博主,有兴趣的小可爱可以来互讨 🎂🎂🎂🎂🎂🎂🎂🎂

🎂个人主页::小小页面🎂

🎂gitee页面:秦大大🎂

🎂🎂🎂🎂🎂🎂🎂🎂

🎂 一个爱分享的小博主 欢迎小可爱们前来借鉴🎂


计数排序

排序的介绍

前面我们学习了插入排序、希尔排序 选择排序 、堆排序 、冒泡排序、快速排序以及归并排序

这些排序都可以在内存中进行排序,不同的是合并排序也可以在磁盘中排序,

怎么在磁盘上排序呢。假设内存只有1G,一个文件里有4G的数据,我们可以通过把这个数据分成4份,每一份我们可以在内存中进行排序,排序好任何写入回去, 然后通过归并排序进行排序好

分配好的每部分先用计数排序进行排序好

计数排序

思路:

遍历一便这个文件数据,统计好这些数值出现的次数,创建一个数组

绝对映射:

找到里面的最大值,以最大值为这个数组的空间,这样很容易造成空间的浪费。

相对映射:

我们可以通过找出其中的最大最小进行相减然后加1,获取到要开辟的大小

我们对每个原数组的元素减去min,然后找到对应的下标的值加1

sql 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
void CountSort(int* a, int size)
{
	int min = INT_MAX;
	int max = INT_MIN;
	int i = 0;
	//找最大和最小
	for (i = 0; i < size; i++)
	{
		max = (a[i] > max ? a[i] : max);
		min = (a[i] < min ? a[i] : min);
	}
	int range = max - min + 1;
	int* newnum = (int*)calloc(range,sizeof(int));
	//开始计数
	for (i = 0; i < size; i++)
	{
		int num = a[i] - min;
		newnum[num]++;
	}
	//开始往原数组覆盖
	for (i = 0; i < range; i++)
	{
		static int j = 0;
		while (newnum[i]--)
		{
			a[j++] = i + min;
		}
	}
	free(newnum);

}
int main()
{
	int a[] = { 5,2,6,1,4,8,5,6,2,1,5,6,1,2,4,9,5,4,2,6,4 };
	CountSort(a, sizeof(a) / sizeof(a[0]));
	int i = 0;
	for (i = 0; i < sizeof(a) / sizeof(a[0]); i++)
	{
		printf("%d ", a[i]);
	}
	return 0;
}

计数排序的优缺点

1.时间复杂度是O(N+ range),要看N和range哪个大

2.适合于整形,且数值相对集中,比如a[10] = {1,200,999999}这个就不能使用了

相关推荐
唐叔在学习3 分钟前
【唐叔学算法】第18天:解密选择排序的双重魅力-直接选择排序与堆排序的Java实现及性能剖析
数据结构·算法·排序算法
Kenneth風车35 分钟前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)11
算法·机器学习·分类
最后一个bug40 分钟前
rt-linux中使用mlockall与free的差异
linux·c语言·arm开发·单片机·嵌入式硬件·算法
蹉跎x2 小时前
力扣1358. 包含所有三种字符的子字符串数目
数据结构·算法·leetcode·职场和发展
rainoway2 小时前
CRDT宝典 - yata算法
前端·分布式·算法
巫师不要去魔法部乱说3 小时前
PyCharm专项训练4 最小生成树算法
算法·pycharm
IT猿手3 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解GLSMOP1-GLSMOP9及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·算法·机器学习·matlab·强化学习
阿七想学习3 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法
王老师青少年编程3 小时前
gesp(二级)(12)洛谷:B3955:[GESP202403 二级] 小杨的日字矩阵
c++·算法·矩阵·gesp·csp·信奥赛
Kenneth風车4 小时前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)111
算法·机器学习·分类