计数排序是一种非比较排序算法,主要通过统计每个值出现的次数来实现排序。它适用于数字范围有限且数据较为分散的情况。与常见的比较排序算法不同,计数排序利用了数组的索引来映射每个数值出现的次数,并通过累加这些次数来确定每个数值的排序位置。

时间复杂度为O(n+k),其中n是待排序元素的数量,k是数值的最大值。空间复杂度为O(k),由于需要为每个可能的值分配一个计数数组。因此,在数值范围k相对较小的时候,计数排序效率较高。

计数排序是稳定的,这意味着相等的元素在排序后仍然保持原有的相对顺序。这一点使得计数排序在某些需要保留元素原始顺序的场景中尤为重要。

计数排序的适用场景包括数值范围较小且数据量大的问题。例如,在图像处理、基因排序或排序学生成绩等问题中,计数排序可以有效提高效率。需要注意的是,当数值范围非常大时,计数排序的空间和时间开销可能会成为瓶颈。

以下是计数排序的C++实现示例:

#include <iostream>
#include <vector>
using namespace std;
void countingSort(vector<int>& arr) {
int maxVal = *max_element(arr.begin(), arr.end());
vector<int> count(maxVal + 1, 0);
for (int num : arr) {
count[num]++;
}
int index = 0;
for (int i = 0; i <= maxVal; i++) {
while (count[i]--) {
arr[index++] = i;
}
}
}
int main() {
vector<int> arr = {4, 2, 2, 8, 3, 3, 1};
countingSort(arr);
for (int num : arr) {
cout << num << " ";
}
return 0;
}

通过理解计数排序的原理,可以在实际应用中优化算法的实现,尤其是在需要处理大量数据且数值范围有限的场景中。