排序算法---桶排序

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

桶排序(Bucket Sort)是一种排序算法,它将待排序的数据分到几个有序的桶中,每个桶再分别进行排序,最后将各个桶中的数据按照顺序依次取出,即可得到有序序列。

具体步骤如下:

  1. 首先确定桶的个数和每个桶的取值范围。通常会根据输入数据的特点来确定桶的个数,例如数据的分布情况、数据量等。
  2. 将待排序的数据依次放入对应的桶中。可以使用映射函数将待排序数据映射到桶中,或者直接使用数据本身作为桶的索引。
  3. 对每个非空的桶进行排序。可以使用插入排序、快速排序、归并排序等排序算法对每个桶中的数据进行排序。
  4. 将各个桶中的数据按照顺序依次取出,即可得到有序序列。

桶排序的时间复杂度取决于对每个桶内部数据进行排序的时间复杂度。假设有n个元素,将它们均匀地分到m个桶中,那么每个桶中平均有n/m个元素。如果对每个桶采用快速排序等线性时间复杂度的排序算法,则桶排序的时间复杂度为O(n+m),其中n为待排序数据的个数,m为桶的个数。如果n和m接近相等,则时间复杂度近似为O(n)。

桶排序的空间复杂度取决于桶的个数和每个桶中数据的个数。通常情况下,桶排序的空间复杂度为O(n+m),其中n为待排序数据的个数,m为桶的个数。如果n和m接近相等,则空间复杂度近似为O(n)。

需要注意的是,桶排序适合用于待排序数据分布比较均匀的情况,如果数据分布不均匀,可能会导致某些桶中的数据量过大,从而影响排序效果。

以下是一个使用C语言实现的桶排序示例:

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

// 桶排序函数
void bucket_sort(int arr[], int n, int max)
{
    // 创建桶数组
    int buckets[max + 1];

    // 初始化桶数组
    for (int i = 0; i <= max; i++)
    {
        buckets[i] = 0;
    }

    // 将元素放入对应的桶中
    for (int i = 0; i < n; i++)
    {
        buckets[arr[i]]++;
    }

    // 从桶中取出元素并排序
    int index = 0;
    for (int i = 0; i <= max; i++)
    {
        while (buckets[i] > 0)
        {
            arr[index++] = i;
            buckets[i]--;
        }
    }
}

int main()
{
    int arr[] = {5, 2, 8, 9, 1};
    int n = sizeof(arr) / sizeof(arr[0]);
    int max = 9; // 假设最大值为9

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

    bucket_sort(arr, n, max);

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

    return 0;
}

上述代码中,首先定义了一个bucket_sort函数,用于实现桶排序。这个函数接受三个参数:待排序数组arr、数组长度n和最大值max

在函数内部,首先创建了一个长度为max+1的桶数组buckets,并将其初始化为0。然后,遍历待排序数组,将每个元素放入对应的桶中,即对应索引位置上的数值加1。

接下来,使用两层循环从桶中取出元素,并按照顺序存放到原始数组arr中。外层循环遍历桶数组,内层循环根据桶中记录的数量,将元素按照顺序放入原始数组,同时将桶中记录数量减1。

main函数中,定义了一个待排序的数组arr,然后调用bucket_sort函数进行排序。最后,输出排序前后的数组结果。

这段代码的核心思想是按照待排序数据的取值范围创建相应数量的桶,将数据按照取值映射到桶中,并对每个桶中的数据进行排序后,再依次取出合并为有序序列。

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

相关推荐
肆悟先生5 分钟前
3.18 constexpr函数
开发语言·c++·算法
别在内卷了7 分钟前
三步搞定:双指针归并法求两个有序数组的中位数(Java 实现)
java·开发语言·学习·算法
范纹杉想快点毕业18 分钟前
C语言100个经典编程练习题(完整标题+清晰排版)
运维·c语言·单片机·嵌入式硬件·算法
0和1的舞者20 分钟前
力扣hot100-链表专题-刷题笔记(一)
数据结构·链表·面试·刷题·知识
Tisfy20 分钟前
LeetCode 2943.最大化网格图中正方形空洞的面积:小小思维
算法·leetcode·题解·数组·思维·排序·连续
難釋懷22 分钟前
Redis数据结构介绍
数据结构·数据库·redis
LDG_AGI22 分钟前
【机器学习】深度学习推荐系统(二十六):X 推荐算法多模型融合机制详解
人工智能·分布式·深度学习·算法·机器学习·推荐算法
高山上有一只小老虎23 分钟前
小红的矩阵染色
java·算法·矩阵
WuChao_JMUer24 分钟前
YOLO26 on RDK S100P 端侧部署技术报告
人工智能·算法·yolo·rdk
Ro Jace24 分钟前
传统雷达信号分选方法之SDIF:Improved algorithm for the deinterleaving of radar pulses
网络·人工智能·算法