箱子排序(Bin Sort)

思想:通过对关键字进行“分配”和“收集”,将相同的关键字放入同一个箱子中(分配),即一个箱子中的所有关键字都是相同的,然后再将所有的箱子链接起来(收集)就得到了有序的链表。

一个例子

step a 输入链表

在这里插入图片描述

step b 分配

在这里插入图片描述

step c 收集

在这里插入图片描述
总的来说,该算法的时间复杂度是线性的即O(n)

#include <cstdlib>
#include <iostream>
using namespace std;

typedef struct LinkNode
{
    int score;
    LinkNode *next;
} LNode, *Node;

void createLinkList(Node h, int n);
void binSort(Node h, int n);
void display(Node h);

int main()
{
    int n;
    cin >> n;
    Node h = new LNode[1];
    h->next = nullptr;
    createLinkList(h, n);
    binSort(h, n);
    display(h);
    system("pause");
    return 0;
}

void createLinkList(Node h, int n)
{ //头插法
    while (n)
    {
        int score;
        Node r = new LNode[1];
        cin >> score;
        r->score = score;
        r->next = h->next;
        h->next = r;
        --n;
    }
}

void binSort(Node h, int n)
{
    Node bin = new LNode[n];
    for (int i = 0; i < n; i++)
        bin[i].next = nullptr;
    Node p, pr;
    p = h->next;
    while (p)
    { //分配
        pr = p;
        p = p->next;
        pr->next = bin[pr->score].next;
        bin[pr->score].next = pr;
    }
    h->next = nullptr;
    for (int i = n - 1; i >= 0; i--)
    { //收集
        while (bin[i].next)
        {
            Node r = bin[i].next;
            bin[i].next = r->next;
            r->next = h->next;
            h->next = r;
        }
    }
    delete[] bin;
}

void display(Node h)
{
    Node p;
    p = h;
    while (p->next)
    {
        cout << p->next->score << " ";
        p = p->next;
    }
    cout << endl;
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值