
如何使用C++中的计数排序算法
计数排序算法是一种比较简单且高效的排序算法,适用于对整数序列进行排序的场景。它的基本思想是确定每个元素前面有多少个元素比它小,从而确定它在有序数组中的位置。
计数排序算法的步骤如下:
下面是一个使用C++语言实现的计数排序算法的示例代码:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <vector>
using namespace std;
void countingSort(vector<int>& arr) {
int max_val = arr[0];
for (int i = 1; i < arr.size(); i++) {
if (arr[i] > max_val) {
max_val = arr[i];
}
}
vector<int> count(max_val + 1, 0);
for (int i = 0; i < arr.size(); i++) {
count[arr[i]]++;
}
for (int i = 1; i < count.size(); i++) {
count[i] += count[i - 1];
}
vector<int> temp(arr.size());
for (int i = arr.size() - 1; i >= 0; i--) {
temp[count[arr[i]] - 1] = arr[i];
count[arr[i]]--;
}
for (int i = 0; i < arr.size(); i++) {
arr[i] = temp[i];
}
}
int main() {
vector<int> arr = {5, 1, 4, 3, 2};
countingSort(arr);
cout << "排序后的数组:";
for (int i = 0; i < arr.size(); i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}以上代码中,我们使用了一个辅助的计数数组来统计每个元素的出现次数,然后通过变形计算每个元素在排序结果中的位置。最后,我们将排序结果复制回原数组。
通过以上示例代码,我们可以看到计数排序算法的实现过程,它的时间复杂度为O(n+k),其中n为待排序序列的长度,k为最大元素值与最小元素值之差加一。
总结起来,计数排序算法是一种简单但高效的排序算法,适用于对整数序列进行排序的场景。通过使用适当的数据结构和算法,我们可以更好地完成排序任务。
以上就是如何使用C++中的计数排序算法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号