C++实现计数排序

void CountSort(int* a, int n)
{
	assert(a);

	int minValue = a[0];
	int maxValue = a[0];
	for (int i = 0; i < n; ++i)
	{
		if (minValue > a[i])
		{
			minValue = a[i];
		}

		if (maxValue < a[i])
		{
			maxValue = a[i];
		}
	}
	int range = maxValue-minValue+1;

	int* tmp = new int[range];
	memset(tmp, 0, sizeof(int)*range);

	int index = 0;
	while (index < n)
	{
		tmp[a[index]-minValue]++;
		++index;
	}

	index = 0;
	for (int i = 0; i < range; ++i)
	{
		while (tmp[i]--)
		{
			a[index++] = i+minValue;
		}
	}

	delete[] tmp;
}

网页标题:C++实现计数排序
转载来于:http://www.hxwzsj.com/article/gcjgsh.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 成都网站制作 移动网站建设 定制网站制作 成都网站设计 成都网站制作 成都品牌网站建设 成都网站建设 成都网站建设 重庆网站建设 企业网站制作 网站制作 手机网站建设 成都网站建设 高端网站设计 上市集团网站建设 四川成都网站制作 成都网站制作 泸州网站建设 专业网站建设 成都营销网站制作 网站建设方案 外贸营销网站建设