排序算法---基数排序

原创不易,转载请注明出处。欢迎点赞收藏~

基数排序是一种非比较型的排序算法,用于对整数进行排序。它将整数按照位数进行分组,从低位到高位依次进行排序,最终得到有序序列。

算法步骤如下:

  1. 找到待排序序列中的最大值,确定需要进行多少轮排序。
  2. 根据最大值的位数,从低位到高位依次进行排序。
  3. 对于每一位进行排序,可以使用稳定的计数排序或桶排序来实现。
  4. 按照每一位的排序结果进行重组,得到新的序列。
  5. 重复步骤3和4,直到最高位排序完成。

时间复杂度:

  • 对于n个d位数的排序,每一位的排序需要O(n)的时间复杂度,共需进行d轮排序,因此总的时间复杂度为O(d*n)。
  • 如果d是常数,那么时间复杂度可以简化为O(n)。

空间复杂度:

  • 由于基数排序需要额外的存储空间来存储中间结果和临时数组,空间复杂度为O(n+k),其中k取决于桶的大小。

基数排序的优点是稳定性高,适用于对大量数据进行排序,尤其是数据位数相同的情况。缺点是对于负数的排序不直接适用,并且需要额外的存储空间。

以下是一个基数排序的C语言示例代码:

cpp 复制代码
#include <stdio.h>

// 获取数组中最大的元素
int get_max(int arr[], int n)
{
    int max = arr[0];
    for (int i = 1; i < n; i++)
    {
        if (arr[i] > max)
        {
            max = arr[i];
        }
    }
    return max;
}

// 使用计数排序对数组进行排序(根据某个位数)
void counting_sort(int arr[], int n, int exp)
{
    int output[n];       // 存储临时结果的数组
    int count[10] = {0}; // 用于计数的数组

    // 统计元素出现的次数
    for (int i = 0; i < n; i++)
    {
        count[(arr[i] / exp) % 10]++;
    }

    // 将count数组更新为每个元素的累加和
    for (int i = 1; i < 10; i++)
    {
        count[i] += count[i - 1];
    }

    // 根据count数组的值,将元素放到output数组中
    for (int i = n - 1; i >= 0; i--)
    {
        output[count[(arr[i] / exp) % 10] - 1] = arr[i];
        count[(arr[i] / exp) % 10]--;
    }

    // 将output数组复制回arr数组
    for (int i = 0; i < n; i++)
    {
        arr[i] = output[i];
    }
}

// 实现基数排序函数
void radix_sort(int arr[], int n)
{
    // 获取数组中最大元素
    int max = get_max(arr, n);

    // 根据位数进行计数排序
    for (int exp = 1; max / exp > 0; exp *= 10)
    {
        counting_sort(arr, n, exp);
    }
}

// 测试基数排序算法
int main()
{
    int arr[] = {170, 45, 75, 90, 802, 24, 2, 66};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("排序前的数组:\n");
    for (int i = 0; i < n; i++)
    {
        printf("%d ", arr[i]);
    }

    radix_sort(arr, n);

    printf("\n排序后的数组:\n");
    for (int i = 0; i < n; i++)
    {
        printf("%d ", arr[i]);
    }
    putchar('\n');

    return 0;
}

以上代码演示了基数排序的实现过程。基数排序是一种非比较性的排序算法,它根据排序元素的位数依次将元素进行桶排序,实现对整个数组的排序。

代码中的 get_max() 函数用于获取数组中的最大元素,这是为了确定需要进行多少轮排序(根据最大元素的位数确定)。

counting_sort() 函数是基数排序中使用的辅助函数,它基于某个位数对数组进行计数排序。首先创建一个临时数组 output 用于存储排序结果,创建一个计数数组 count,初始化为全零。然后,遍历数组并根据当前位数将元素计数加一。接下来,将 count 数组更新为每个元素的累加和,这样 count 数组的值就表示小于等于当前数字的元素个数。最后,根据 count 数组的值,将元素放到 output 数组中,并更新 count 数组的值。最后,将 output 数组复制回原数组。

radix_sort() 函数是实现基数排序的主要函数。它通过迭代不同位数进行计数排序,直到排完最高位数为止。

main() 函数中,我们定义了一个测试数组 arr,然后调用 radix_sort() 函数对其进行排序,并输出排序后的结果。

运行如上代码,你可以看到以下输出:

相关推荐
AI软著研究员1 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish2 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱2 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者18 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮19 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者19 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考19 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx1 天前
CART决策树基本原理
算法·机器学习
Wect1 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱1 天前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法