【408数据结构与算法】—基数排序(桶排序)(二十三)

简介: 基数排序也叫桶排序或箱排序,设置若干箱子,将关键字为k的记录放入第k个箱子,然后按序号将非空的连接。

【408数据结构与算法】—基数排序(桶排序)(二十三)

基本思想:分配+收集

基数排序也叫桶排序或箱排序,设置若干箱子,将关键字为k的记录放入第k个箱子,然后按序号将非空的连接。

基数排序:数字是有范围的,均由0-9这是个数字组成,则只需设置十个箱子,相继按个、十、百……进行排序。

2345_image_file_copy_363.jpg

2345_image_file_copy_364.jpg

2345_image_file_copy_365.jpg

C语言代码实现:

//基数排序
void RadixSort(int* arr, int n)
{
  //max为数组中最大值
  int max = arr[0];
  int base = 1;
  //找出数组中的最大值
  for (int i = 0; i < n; i++)
  {
    if (arr[i] > max)
    {
      max = arr[i];
    }
  }
  //循环结束max就是数组最大值
  //临时存放数组元素的空间
  int* tmp = (int*)malloc(sizeof(int)*n);
  //循环次数为最大数的位数
  while (max / base > 0)
  {
    //定义十个桶,桶里面装的不是数据本身,而是每一轮排序对应(十、白、千...)位的个数
    //统计每个桶里面装几个数
    int bucket[10] = { 0 };
    for (int i = 0; i < n; i++)
    {
      //arr[i] / base % 10可以取到个位、十位、百位对应的数字
      bucket[arr[i] / base % 10]++;
    }
    //循环结束就已经统计好了本轮每个桶里面应该装几个数
    //将桶里面的元素依次累加起来,就可以知道元素存放在临时数组中的位置
    for (int i = 1; i < 10; i++)
    {
      bucket[i] += bucket[i - 1];
    }
    //循环结束现在桶中就存放的是每个元素应该存放到临时数组的位置
    //开始放数到临时数组tmp
    for (int i = n - 1; i >= 0; i--)
    {
      tmp[bucket[arr[i] / base % 10] - 1] = arr[i];
      bucket[arr[i] / base % 10]--;
    }
    //不能从前往后放,因为这样会导致十位排好了个位又乱了,百位排好了十位又乱了
    /*for (int i = 0; i < n; i++)
    {
      tmp[bucket[arr[i] / base % 10] - 1] = arr[i];
      bucket[arr[i] / base % 10]--;
    }*/
    //把临时数组里面的数拷贝回去
    for (int i = 0; i < n; i++)
    {
      arr[i] = tmp[i];
    }
    base *= 10;
  }
  free(tmp);
}

二、基数排序算法分析

  • 时间效率:O(k*(n+m)
  • k:关键字个数
  • m:关键字取值范围为m个值
  • 空间效率:O(n+m)
  • 稳定性:稳定

基数排序算法分析

例如:10000个人按照生日排序

2345_image_file_copy_366.jpg

总结

2345_image_file_copy_367.jpg

相关文章
|
3月前
|
算法 搜索推荐 Java
数据结构与算法学习十三:基数排序,以空间换时间的稳定式排序,速度很快。
基数排序是一种稳定的排序算法,通过将数字按位数切割并分配到不同的桶中,以空间换时间的方式实现快速排序,但占用内存较大,不适合含有负数的数组。
50 0
数据结构与算法学习十三:基数排序,以空间换时间的稳定式排序,速度很快。
|
3月前
|
搜索推荐 Java Go
深入了解基数排序算法
深入了解基数排序算法
41 3
|
3月前
|
搜索推荐 Java Go
探究桶排序算法
探究桶排序算法
44 1
|
3月前
|
数据可视化 搜索推荐 Python
Leecode 刷题笔记之可视化六大排序算法:冒泡、快速、归并、插入、选择、桶排序
这篇文章是关于LeetCode刷题笔记,主要介绍了六大排序算法(冒泡、快速、归并、插入、选择、桶排序)的Python实现及其可视化过程。
32 0
|
5月前
|
存储 搜索推荐 算法
Python中的桶排序算法
总结而言,桶排序是一个非常高效的排序算法,尤其适用于数据分布均匀的情况。正确实现和使用桶排序可以在特定情况下获得极高的排序速度。
33 0
|
6月前
|
算法 搜索推荐 C#
|
6月前
|
算法 搜索推荐 C#
|
7月前
|
机器学习/深度学习 并行计算 搜索推荐
程序技术好文:桶排序算法及其Java实现
程序技术好文:桶排序算法及其Java实现
49 0
|
8月前
|
算法 前端开发
前端算法之基数排序
前端算法之基数排序
52 1
|
7月前
|
算法 C语言
数据结构和算法——桶排序和基数排序(图示、伪代码、多关键字排序,基数排序代码)
数据结构和算法——桶排序和基数排序(图示、伪代码、多关键字排序,基数排序代码)
69 0

热门文章

最新文章