经典算法之基数排序

如大家所了解的,基数排序是一种非比较型整数排序算法,其原理是将整数按位数切割成不同的数字,然后按每个位数分别比较。

一般来说,排序过程是将所有待比较数值统一为同样的数位长度,数位较短的数前面补零,然后从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后, 数列就变成一个有序序列。

排序代码实现如下:

复制代码
int getMax(int arr[], int n) 
{ 
    int mx = arr[0]; 
    for (int i = 1; i < n; i++) 
        if (arr[i] > mx) 
            mx = arr[i]; 
    return mx; 
} 

void countSort(int arr[], int n, int exp) 
{ 
    int output[n]; 
    int i, count[10] = {0}; 
  
    for (i = 0; i < n; i++) 
        count[ (arr[i]/exp)%10 ]++; 
  
    for (i = 1; i < 10; i++) 
        count[i] += count[i - 1]; 
  
    for (i = n - 1; i >= 0; i--) 
    { 
        output[count[ (arr[i]/exp)%10 ] - 1] = arr[i]; 
        count[ (arr[i]/exp)%10 ]--; 
    } 
  
    for (i = 0; i < n; i++) 
        arr[i] = output[i]; 
} 
  
void radixsort(int arr[], int n) 
{ 
    int m = getMax(arr, n); 
    for (int exp = 1; m/exp > 0; exp *= 10) 
        countSort(arr, n, exp); 
} 
相关推荐
是店小二呀1 小时前
【算法-BFS 解决最短路问题】探索BFS在图论中的应用:最短路径问题的高效解法
算法·图论·宽度优先
qq_513970441 小时前
力扣 hot100 Day46
算法·leetcode
满分观察网友z2 小时前
递归与迭代的优雅之舞:我在评论区功能中悟出的“树”之道(104. 二叉树的最大深度)
后端·算法
m0_535064602 小时前
类模版的相关案例
算法
Chirp2 小时前
手撕ultralytics,换用Lightning训练yolo模型
算法
2301_801821713 小时前
机器学习-线性回归模型和梯度算法
python·算法·线性回归
电院大学僧3 小时前
初学python的我开始Leetcode题-13
python·算法·leetcode
enzeberg3 小时前
全面解析前端领域的算法
算法
阑梦清川4 小时前
使用C语言原生的字符串函数求解的一道题目总结
算法
阑梦清川4 小时前
算法竞赛小白晋级之路---高精度减法(题目+解析+代码)
算法