C/C++基数排序

编程入门 行业动态 更新时间:2024-10-10 23:26:58

C/C++<a href=https://www.elefans.com/category/jswz/34/1738537.html style=基数排序"/>

C/C++基数排序

基数排序

基数排序是按照低位先排序,然后收集;再按照高位排序,然后再收集;依次类推,直到最高位。有时候有些属性是有优先级顺序的,先按低优先级排序,再按高优先级排序。最后的次序就是高优先级高的在前,高优先级相同的低优先级高的在前。

算法描述

  • 取得数组中的最大数,并取得位数;
  • arr为原始数组,从最低位开始取每个位组成radix数组;
  • 对radix进行计数排序(利用计数排序适用于小范围数的特点);

动态演示

代码实现

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int maxbit(vector<int>& data, int n) //辅助函数,求数据的最大位数
{int maxData = data[0];           // 最大数/// 先求出最大数,再求其位数,这样有原先依次每个数判断其位数,稍微优化点。for (int i = 1; i < n; ++i){if (maxData < data[i])maxData = data[i];}int d = 1;int p = 10;while (maxData >= p){//p *= 10; // Maybe overflowmaxData /= 10;++d;}return d;
}
void radixsort(vector<int>& data) //基数排序
{int n = data.size();int d = maxbit(data, n);int* tmp = new int[n];int* count = new int[10]; //计数器int i, j, k;int radix = 1;for (i = 1; i <= d; i++) //进行d次排序{//每次分配前清空计数器for (j = 0; j < 10; j++)count[j] = 0; //统计每个桶中的记录数for (j = 0; j < n; j++){k = (data[j] / radix) % 10; count[k]++;}//将tmp中的位置依次分配给每个桶,求前缀和for (j = 1; j < 10; j++)count[j] += count[j - 1]; //将所有桶中记录依次收集到tmp中for (j = n - 1; j >= 0; j--) {k = (data[j] / radix) % 10;tmp[count[k] - 1] = data[j];count[k]--;}//将临时数组的内容复制到data中for (j = 0; j < n; j++) data[j] = tmp[j];//位数加1radix = radix * 10;}delete[]tmp;delete[]count;
}void print_arr(vector<int>& arr) {int n = arr.size();for (int i = 0; i < n; i++) {cout << arr[i] << "  ";}cout << endl;
}
int main() {vector<int> arr = { 3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};cout << "排序前:" << endl;print_arr(arr);radixsort(arr);cout << "排序后:" << endl;print_arr(arr);system("pause");return 0;
}

结果输出

更多推荐

C/C++基数排序

本文发布于:2023-07-28 19:12:54,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1284020.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:基数

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!