前言
原理后续补齐。
代码
public static int[] countSort(int[] array)
{
// 取得计数排序范围
int max = array[0];
int min = array[0];
for (int i = 1; i < array.Length; i++)
{
if (array[i] > max)
{
max = array[i];
}
if (array[i] > min)
{
min = array[i];
}
}
int d = max - min;
// 将数组填充
int[] countArray = new int[d+1];
for (int i=0; i < array.Length; i++)
{
// 如果有某个数就加1
countArray[array[i]-min]++;
}
// 统计数组,每个是前面数组之和
for (int i=1;i<countArray.Length;i++)
{
countArray[i] += countArray[i - 1];
}
//开始排序
int[] sortedArray = new int[array.Length];
for (int i=array.Length-1;i>=0;i--)
{
sortedArray[countArray[array[i] - min]-1]=array[i];
countArray[array[i] - min]--;
}
return sortedArray;
}