C语言必学的12个排序算法:桶排序(第10篇)

基本思想

桶排序(bucket sort),和计数排序(参见前一篇文章)有些类似,同样是线性排序算法,基本思想是将输入的待排序列n个整数数据元素,根据每个数据元素的取值范围[0,k],划分称为m个区间,每个区间称为桶,每个桶存放该区间的数据元素,由于每个桶内的数据元素个数不确定,可以使用链表表示,同时使用插入排序,让每个桶的链表有序。这样按照次序将所有桶的元素连起来就得到完整的有序列表。

桶排序,和计数排序一样,对输入的数据元素有一定要求,需要根据数据元素特征容易划分桶,具体问题具体分析,以下均以常用的整数排序为例。

这里以整数排序为例子。例如有100个整数,每个整数取值范围[000-999],备注:桶排序要求整数取值值是十进制位数相等。

计数排序,根据取值范围申请1000个元素的数组用于计数,当整数取值范围过大时,内存空间浪费严重;

桶排序可以将取值范围1000划分10个区间,例如百分位的十进制数字,划分10个区间,也就是10个桶,[000-099]-[100-199]…[900-999],这样将待排的100个整数根据百分位数字分配到10个桶,每个桶指向链表的第一个结点,并且使用插入排序进行排序。

代码实现

1.区间划分,使用数组即可。

2.每个桶需要创建链表和进行链表插入排序。

 /*
#include <stdio.h>
#include <stdlib.h>

struct node
{
  int data;
  struct node *next
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值