代码
main.cpp
#include <iostream>
#include <list>
using namespace std;
void RadixSort(int data[],int n);
int Maxdigit(int data[],int n);
int main()
{
cout<<"RadixSort:"<<endl;
int data[10] = {179,208,306,93,859,934,55,9,271,33};
cout<<"Before:"<<endl;
for(int i=0;i<10;i++)
{
cout<<data[i]<<" ";
}
cout<<endl;
RadixSort(data,10);
cout<<"After:"<<endl;
for(int i=0;i<10;i++)
{
cout<<data[i]<<" ";
}
cout<<endl;
return 0;
}
/*排序*/
void RadixSort(int data[],int n)
{
int digit = Maxdigit(data,n);//根据最大位数判断循环多少次
list<int> list[10];//用数组定义十个链表(十进制)。二进制定义两个。八进制定义八个
int d,j,k,factor;//factor控制提取个位、十位、百位等
for(d = 1,factor=1;d<=digit;factor*=10,d++)//根据最大数几位循环几次
{
for(j=0;j<n;j++)//将元素从数组复制到对应的链表里
{
list[(data[j]/factor)%10].push_back(data[j]);//提取每个数的个位、十位、百位,并放入对应的链表中
}
for(j=k=0;j<10;j++)//将链表里的数再放回数组中
{
while(!list[j].empty())//判断链表是否为空
{
data[k++] = list[j].front();//将链表数据放到数组
list[j].pop_front();//删除链表中已放入到数组中的元素
}
}
cout<<"IntermediateResults-"<<d<<":"<<endl;//第一次按个位排,第二次按十位排,第三次按百位排
for(int m=0;m<n;m++)
{
cout<<data[m]<<" ";
}
cout<<endl;
}
}
/*检测最大的数是多少位*/
int Maxdigit(int data[],int n)
{
int d = 1;
int p = 10;
for(int i = 0;i < n;++i)
{
while(data[i] >= p)
{
p *= 10;
++d;
}
}
return d;
}