计数排序的基本思想是:对于每一个输入元素x,确定小于x的元素个数。根据这些信息,就能准确的将每个数字放在正确的位置上。
在排序的过程中,除了输入数组A[n]之外,还需要一个记录结果的数组B[n]和一个记录小于x数的个数数组C[num_max]。A与B的数组等长,而C数组的长度则为n个数中的最大者。
上图为计数排序的一系列过程,下面依次做分析:
int max_num(int *a, int count)
{
int max = a[0];
for (int i = 1; i < count; i++)
{
if (a[i] > max)
max = a[i];
}
return max+1;
}
int* counting_sort(int* a, int count)
{
int max, *b, *c;
max = max_num(a, count);
b = (int*)malloc(count * 2);
c = (int*)malloc(max * 2);
//统计A中与C下标相等的元素,即图(a)
for (int i = 0; i < max; i++)
{
int c_count = 0;
for (int j = 0; j < count; j++)
{
if (i == a[j]) c_count++;
}
c[i] = c_count;
}
//统计小于等于元素X的数组个数,即图(b)
for (int i = 0; i < max - 1; i++)
{
c[i + 1] += c[i];
}
//开始排序,即图(c)(d)(e)
for (int i = 0; i < count; i++)
{
b[c[a[i]] - 1] = a[i];
c[a[i]]--;
}
return b;
}
void main()
{
int count, *p;
printf("请输入需要排序的数的个数 :");
scanf_s("%d", &count);
p = (int*)malloc(count * 2);
printf("\n请输入需要排序的%d个数字:",count);
for (int i = 0; i < count; i++)
{
scanf_s("%d", p+i);
}
printf("\n快速排序后的数组:");
p = counting_sort(p, count);
for (int i = 0; i < count; i++)
{
printf("%d ", p[i]);
}
printf("\n");
system("pause");
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/jing_unique_da/article/details/46659131