基数排序

 

思想:

基数排序(Radix Sort)是桶排序的扩展,它的基本思想是:将整数按位数切割成不同的数字,然后按每个位数分别比较。

具体做法是:将所有待比较数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后, 数列就变成一个有序序列。

基数排序图文说明

基数排序图文说明

通过基数排序对数组{53, 3, 542, 748, 14, 214, 154, 63, 616},它的示意图如下:

在上图中,首先将所有待比较树脂统一为统一位数长度,接着从最低位开始,依次进行排序。

1. 按照个位数进行排序。

2. 按照十位数进行排序。

3. 按照百位数进行排序。

排序后,数列就变成了一个有序序列。

实现方法:

// letcode.cpp : 定义控制台应用程序的入口点。
//
#include"stdafx.h"
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
using namespace std;

int getmax(int *a, int n)
{
	int max = a[0];
	for (int i = 1; i < n; i++)
	{
		if (a[i] > max)
			max = a[i];
	}
	return max;

}
void countsort(int *a, int n,int exp)
{
	int output[9];
	int bucks[10] = {0};
	for (int i = 0; i <n; i++)
	{
		bucks[(a[i] / exp)% 10]++;
	}
	for (int i = 1; i < 10; i++)
	{
		bucks[i] += bucks[i-1];
	}
	for (int i = n - 1; i >= 0; i--)
	{
		output[bucks[(a[i] / exp) % 10] - 1] = a[i];
		bucks[(a[i] / exp) % 10]--;
	}
	for (int i = 0; i < n; i++)
		a[i] = output[i];
}
void radix_Sort(int *a, int n)
{
	int max=getmax(a, n);
	int exp = 1;
	for (int exp = 1; max / exp > 0; exp *= 10)
		countsort(a,n,exp);
}
int main()
{
	int i;
	int a[] = { 53, 3, 542, 748, 14, 214, 154, 63, 616 };
	int ilen = (sizeof(a)) / (sizeof(a[0]));

	cout << "before sort:";
	for (i = 0; i<ilen; i++)
		cout << a[i] << " ";
	cout << endl;

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

	cout << "after  sort:";
	for (i = 0; i<ilen; i++)
		cout << a[i] << " ";
	cout << endl;
	system("pause");
	return 0;
}

总结:

基数排序中用到了计数排序,计数排序主要包括四步:

1)将数据出现的次数存储在桶buckets中

2)更改buckets[i]。目的是让更改后的buckets[i]的值,是该数据在output[]中的位置。

3)将数据存储到临时数组output[]中

4) 将排序好的数据赋值给a[]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值