排序算法九:基数排序

排序算法九:基数排序

代码

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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值