程序分享--排序算法--基数排序

关注我,持续分享逻辑思维&管理思维; 可提供大厂面试辅导、及定制化求职/在职/管理/架构辅导;

有意找工作的同学,请参考博主的原创:《面试官心得--面试前应该如何准备》,《面试官心得--面试时如何进行自我介绍》《做好面试准备,迎接2024金三银四》。
推荐热榜内容:《架构实战--以海量存储系统讲解热门话题:分布式概念** 》**

-------------------------------------正文----------------------------------------

基数排序:概述

基数排序(Radix Sort)是桶排序的扩展,它的基本思想是:将整数按位数切割成不同的数字,然后按每个位数分别比较。

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

基数排序:算法描述

1.取得数组中的最大数,并取得位数;

2.arr为原始数组,从最低位开始取每个位组成radix数组;

3.对radix进行计数排序(利用计数排序适用于小范围数的特点);

cpp 复制代码
#include <iostream>
#include <vector>
#include <queue>
 
void radixSort(std::vector<int>& arr)
{
    int maxDigit = 0;
    // 找出数组中最大数的最大位数
    for (int i = 0; i < arr.size(); i++) {
        int temp = arr[i];
        while (temp) {
            temp /= 10;
            maxDigit = maxDigit > (i + 1) ? maxDigit : (i + 1);
        }
    }
 
    std::vector<std::queue<int>> buckets(10); // 建立10个桶
    for (int digit = 0; digit < maxDigit; digit++) {
        // 将数分配到桶中
        for (int i = 0; i < arr.size(); i++) {
            int digitVal = (arr[i] / (int)pow(10, digit)) % 10;
            buckets[digitVal].push(arr[i]);
        }
 
        // 再将桶中的数回收到原数组中
        int index = 0;
        for (int i = 0; i < buckets.size(); i++) {
            while (!buckets[i].empty()) {
                arr[index++] = buckets[i].front();
                buckets[i].pop();
            }
        }
    }
}
 
int main() {
    std::vector<int> arr = {170, 45, 75, 90, 802, 24, 2, 66};
    radixSort(arr);
 
    for (int num : arr) {
        std::cout << num << " ";
    }
 
    return 0;
}
相关推荐
奔跑吧 android17 分钟前
【linux kernel 常用数据结构和设计模式】【数据结构 2】【通过一个案例属性list、hlist、rbtree、xarray数据结构使用】
linux·数据结构·list·kernel·rbtree·hlist·xarray
汉克老师19 分钟前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯
Mr_Xuhhh1 小时前
项目需求分析(2)
c++·算法·leetcode·log4j
默默无名的大学生2 小时前
数据结构—顺序表
数据结构·windows
c++bug2 小时前
六级第一关——下楼梯
算法
PAK向日葵2 小时前
【C/C++】面试官:手写一个memmove,要求性能尽可能高
c语言·c++·面试
Morri32 小时前
[Java恶补day53] 45. 跳跃游戏Ⅱ
java·算法·leetcode
林木辛2 小时前
LeetCode热题 15.三数之和(双指针)
算法·leetcode·双指针
AndrewHZ2 小时前
【3D算法技术】blender中,在曲面上如何进行贴图?
算法·3d·blender·贴图·三维建模·三维重建·pcg
Jared_devin3 小时前
二叉树算法题—— [蓝桥杯 2019 省 AB] 完全二叉树的权值
数据结构·c++·算法·职场和发展·蓝桥杯