九大排序之——基数排序
来源:互联网 发布:验证码js ajax demo 编辑:程序博客网 时间:2024/05/16 10:26
基数排序
算法思想:基数排序又称为“桶子法”,从低位开始将待排序的数按照这一位的值放到相应的编号为0~9的桶中。等到低位排完得到一个子序列,再将这个序列按照次低位的大小进入相应的桶中,一直排到最高位为止,数组排序完成。
分类:
LSD——从低位向高位排
MSD——从高位向低位排
算法执行步骤:
(1)遍历序列找出最大的数(为的是确定最大的数是几位数);
(2)开辟一个与数组大小相同的临时数组tmp;
(3)用一个count数组统计原数组中某一位(从低位向高位统计)相同的数据出现的次数;
(4)用一个start数组计算原数组中某一位(从最低位向最高位计算)相同数据出现的位置;
(5)将桶中数据从小到大用tmp数组收集起来;
(6)重复(3)(4)(5)直到所有位都被统计并计算过,用tmp收集起来;
(7)将tmp数组拷回到原数组中;
图示:
代码实现:
int GetMaxDigit(int* arr, size_t n){assert(arr);int digit = 1;int base = 10;for (size_t i = 0; i < n; i++){while (arr[i] >= base){++digit;base *= 10;}}return digit;}void LSDSort(int* arr,size_t n){assert(arr);int base = 1;int digit = GetMaxDigit(arr, n);int* tmp = new int[n];while (digit--){int count[10] = { 0 };//统计某一位出现相同数字的个数for (size_t i = 0; i < n; i++){int index = arr[i] / base % 10;count[index]++;}int start[10] = { 0 };//统计个位相同的数在数组arr中出现的位置for (size_t i = 1; i < n; i++){start[i] = count[i - 1] + start[i - 1];}//初始化tmp数组memset(tmp, 0, n*sizeof(int));//从桶中重新排序数据for (size_t i = 0; i < n; ++i){int index = arr[i] / base % 10;tmp[start[index]++] = arr[i];}//将tmp数组中的元素拷回原数组memcpy(arr, tmp, n*sizeof(int));base *= 10;}delete[] tmp;}void Print(int* arr, size_t n){for (size_t i = 0; i < n; i++){cout << arr[i] << " ";}cout << endl;}void TestLSDSort(){int arr[10] = { 123, 234, 543, 324, 568, 975, 547, 672, 783, 239 };LSDSort(arr, sizeof(arr) / sizeof(arr[0]));Print(arr, sizeof(arr) / sizeof(arr[0]));}
运行结果:
时间复杂度&空间复杂度&稳定性
时间复杂度:O(N*digit)
空间复杂度:O(N)
稳定性:稳定
阅读全文
0 0
- 九大排序之——基数排序
- 三大排序之基数排序
- 九大排序之——希尔排序
- 九大排序之——冒泡排序
- 九大排序之——堆排序
- 九大排序之——选择排序
- 九大排序之——插入排序
- 九大排序之——快速排序
- 九大排序之——归并排序
- 九大排序之——计数排序
- 排序算法九:基数排序
- 排序算法九:基数排序
- 线性时间排序之——基数排序
- 经典排序算法之——基数排序
- 算法——排序之基数排序
- 三大线性排序之基数排序
- 排序——基数排序
- 排序——基数排序
- 交通标志识别
- Jquery的ajax方法跳入error引发的一系列问题
- hdu1028 整数划分
- bootstrap:时间选择器datetimepicker调用
- 使用Spring MVC创建REST服务
- 九大排序之——基数排序
- 解码(改)
- javaday53_IO流_文件分割与文件合并的综合应用
- 周末要学习大数据,先了解了解。
- Repeated DNA Sequences
- oracle中的rownum属性
- Java一些集合的理解
- 洛谷 P1162 填涂颜色
- define认识