排序算法之基数排序

基数排序(Radix Sort)是桶排序的扩展,它的基本思想是:将整数按位数切割成不同的数字,然后按每个位数分别比较。
具体做法是:将所有待比较数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后, 数列就变成一个有序序列。

对于一般的基数排序有通常有两种排序算法:主位优先算法(Most Significant Digit Sort,简称MSD)和次位优先算法(Least Significant Digit Sort,简称LSD)。以扑克牌为例,将花色作为最主位关键字,面值是最次位关键字。MSD是以花色建立桶,LSD是以面值建立桶。

代码如下:

/************************************************************************
*
* 文件名:9.1.2.cpp
*
* 文件描述:基数排序
*
* 创建人:  fdk

* 时  间:  2018-09-25
*
* 版本号:1.0
*
* 修改记录:
*
************************************************************************/

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<string>
#include<vector>
#include<stack>
#include<bitset>
#include<cstdlib>
#include<cmath>
#include<set>
#include<list>
#include<deque>
#include<map>
#include<queue>
#include<limits.h>
using namespace std;

/*获取数组中的最大值*/
int getMax(int a[], int n)
{
    int i, max;
    max = a[0];
    for (i = 1; i < n; i++)
    {
        if (a[i] > max)
        {
            max = a[i];
        }
    }
    return max;
}

/*对数组按照“某个位数”进行桶排序*/
void countSort(int a[], int n, int exp)
{
    int output[n];  //存储被排序数据的临时数组
    int i, buckets[10] = {0};

    /*将数据出现的次数存储在buckets[]中*/
    for (i = 0; i < n; i++)
    {
        buckets[(a[i] / exp) % 10]++;
    }

    /*更改buckets[i]。目的是让更改后的buckets[i]的值,是该数据在output[]中的位置*/
    for (i = 1; i < 10; i++)
    {
        buckets[i] += buckets[i-1];
    }

    /*将数据存储到临时数组output[]中*/
    for (i = n-1; i >= 0; i--)
    {
        output[buckets[(a[i] / exp) % 10]-1] = a[i];
        buckets[(a[i]/exp) % 10] --;
    }

    /*将排序好的数据赋值给a[]*/
    for (i = 0; i < n; i++)
    {
        a[i] = output[i];
    }

}

/*基数排序*/
void radixSort(int a[], int n)
{
    int exp;  //指数。当数组按各位进行排序时,exp = 1; 按十位进行排序时,exp=10
    int max = getMax(a, n); //数组a中的最大值

    //从个位开始,对数组a按指数进行排序
    for (exp = 1; max/exp > 0; exp *= 10)
    {
        countSort(a, n, exp);
    }
}
int main()
{
    int i;
    int a[] = {64, 8, 216, 512, 27, 729, 0, 1, 343, 125};
    int ilen = (sizeof(a)) / (sizeof(a[0]));

    cout << "排序之前的顺序为:";
    for (i = 0; i < ilen; i++)
    {
        cout << a[i] << " ";
    }
    cout << endl;

    radixSort(a, ilen); //基数排序

    cout << "排序之后的顺序为:";
    for (i = 0; i < ilen; i++)
    {
        cout << a[i] << " ";
    }
    cout << endl;


    return 0;
}

 参考博客:https://www.cnblogs.com/skywang12345/p/3603669.html

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值