1 基数排序的特点是研究多个关键字key,且多个key之间有权重之分,

   或者可把单个key建模为含有多个key的排序

而计数排序、桶排序始终只有个一个key,或者说围绕着一个比较规则

Ex:比较年月日,先比较年份,如果相同,比较月份,如果还是相同,就比较日

2 根据首先选择有效位的不同,分为两种

A. 先比较最高有效位,然后在比较次高位的有效位,以此类推进行比较MSD(Most Significant Dight)

     假如有189,321,312,167 需要考虑高有效位相同的情况与不同的情况

最高位不同:直接分出大小,并且需要记住312与321 > 比189,167大

最高位相同:比较十位,并且根据上述记录只比较312与321之间的十位数,否则排序是不稳定的

B. 先比较最低有效位,然后在比较次低位的有效位,以此类推进行比较LSD(Least Significant Dight)

无需考虑MSD排序遇到的问题,直接对每个位数排序即可

注意:每次排序只针对当前位数(辅助排序函数必须是基于稳定的)

3 可以使用基数排序对一些位数有限的十进制数排序(十进制整数每位固定大小0~9)

4 基数排序时间代价 O(d(n+k))(前提是辅助函数为计数排序的情况下)

d为关键值key的位数的个数,每位排序执行计数排序需要O(n+k)

 #include <iostream>
#include <crtdbg.h>
#include <cstring>
using namespace std; const int SIZE = ; //n的大小
const int K = ; //允许的最大整数
enum numberBit
{
GeWei = ,
ShiWei = ,
BaiWei = ,
QianWei = ,
};
//获取当前位数,d表示位数
int GetData(const int data, int d)
{
int tmp = ;
switch(d)
{
case GeWei:
{
tmp = data%;
}
break;
case ShiWei:
{
tmp = data%;
tmp = tmp/;
}
break;
case BaiWei:
{
tmp = data%;
tmp = tmp/;
}
break;
case QianWei:
{
tmp = data/; //允许最大值为1000
}
break;
default:
{
cout <<"wrong number, which big then k";
return -;
}
break;
}
return tmp;
}
//计数排序, d为当前位数
void CountingSort(int array[], int size, int d)
{
//建立辅助数组pCount大小固定为10(0~9),用来存储统计的元素信息
int *pCount = new int[];
memset(pCount, , ()*sizeof(pCount[])); //建立辅助数组result存储结果
int *result = new int[size];
memset(result, , size*sizeof(result[])); //数组p使用元素大小做为下标,统计array的每个元素的个数
for(int i=; i<; ++i)
{
int position = GetData(array[i], d); //获取元素的位置
pCount[position] = pCount[position] + ;
} //数组p 记录每个元素x在数组array中 小于或等于x的个数
//比如个位数时:小于等于4 的为元素 为3个(0, 1000, 83)
for (int i=; i<=; ++i)
{
pCount[i] = pCount[i]+pCount[i-];
} //根据上述获取的信息,进行排序
//比如个位数时:小于等于4的为元素为3个(0, 1000, 83),4的位置为第4个
for (int i=size-; i>=; --i)//此处为保证稳定性,从size-1 向 0 迭代
{
int data = GetData(array[i], d);
int position = pCount[data]; //获取数组array[i]的位置
result[position-] = array[i]; //放到正确的位置
pCount[data]= pCount[data] - ; //更新该元素的个数
}
//把结果存储到最初的数组array
for (int i=; i<size; ++i)
{
array[i] = result[i];
}
delete [] pCount;
delete [] result;
}
//基数排序,k为允许的最大整数
void RadixSort(int array[], int size, int k)
{
//选择稳定排序即可,计数排序或者桶排序(桶排序具体实现请转到上一节)
for (int i=; i<=k; i=i*) //i表示位数,从低有效位到高有效位 LSD
{
CountingSort(array, size, i); //计数排序
}
}
void main()
{
//检测是否有内存泄露 需要加头文件#include <crtdbg.h>
_CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF); int array[SIZE] = {, , , , , , , , , ,}; RadixSort(array, SIZE, K); for (int i=; i<SIZE; ++i)
{
cout << array[i] << endl;
} system("pause");
}

(转载请注明作者和出处^_*  Seven++ http://www.cnblogs.com/sevenPP/  )

基数排序(RadixSort)的更多相关文章

  1. 排序算法----基数排序(RadixSort(L))单链表智能版本

    转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...

  2. 排序算法----基数排序(RadixSort(L,max))单链表版本

    转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...

  3. 模板化的七种排序算法,适用于T* vector<T>以及list<T>

    最近在写一些数据结构以及算法相关的代码,比如常用排序算法以及具有启发能力的智能算法.为了能够让写下的代码下次还能够被复用,直接将代码编写成类模板成员函数的方式,之所以没有将这种方式改成更方便的函数模板 ...

  4. 6种基础排序算法java源码+图文解析[面试宝典]

    一.概述 作为一个合格的程序员,算法是必备技能,特此总结6大基础算法.java版强烈推荐<算法第四版>非常适合入手,所有算法网上可以找到源码下载. PS:本文讲解算法分三步:1.思想2.图 ...

  5. 20172328 2018-2019《Java软件结构与数据结构》第五周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第五周学习总结 概述 Generalization 本周学习了第九章:排序与查找,主要包括线性查找和二分查找算法和几种排序 ...

  6. Java排序算法总结(转载)

    排序算法 平均时间复杂度 冒泡排序 O(n2) 选择排序 O(n2) 插入排序 O(n2) 希尔排序 O(n1.5) 快速排序 O(N*logN) 归并排序 O(N*logN) 堆排序 O(N*log ...

  7. C语言实现排序

    //C语言版排序#include<stdio.h> #include<stdlib.h> //冒泡排序 void bubleSort(int data[], int n); / ...

  8. 十大基础排序算法[java源码+动静双图解析+性能分析]

    一.概述 作为一个合格的程序员,算法是必备技能,特此总结十大基础排序算法.java版源码实现,强烈推荐<算法第四版>非常适合入手,所有算法网上可以找到源码下载. PS:本文讲解算法分三步: ...

  9. 浅谈后缀数组SA

    这篇博客不打算讲多么详细,网上关于后缀数组的blog比我讲的好多了,这一篇博客我是为自己加深印象写的. 给你们分享了那么多,容我自私一回吧~ 参考资料:这位dalao的blog 一.关于求Suffix ...

随机推荐

  1. 怎样在osg中动态的设置drawable的最近最远裁剪面

    // draw callback that will tweak the far clipping plane just    // before rendering a drawable.    s ...

  2. 【工作记录】android手势事件操作记录

    /* 用户按下触摸屏.快速移动后松开 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float vel ...

  3. Java 计算两个日期相差月数

    package com.myjava; import java.text.ParseException;import java.text.SimpleDateFormat;import java.ut ...

  4. 通过缓存数据库结果提高PHP性能(转)

    众所周知,缓存数据库查询的结果可以显著缩短脚本执行时间,并最大限度地减少数据库服务器上的负载.如果要处理的数据基本上是静态的,则该技术将非常有效.这是因为对远程数据库的许多数据请求最终可以从本地缓存得 ...

  5. Asp.Net 之 使用Form认证实现用户登录 (LoginView的使用)

    1. 创建一个WebSite,新建一个页面命名为SignIn.aspx,然后在页面中添加如下的代码 <div class="div_logView"> <asp: ...

  6. Code the Tree

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2292   Accepted: 878 Description A tree ...

  7. iOS 生成本地验证码

    在应用程序注册.登陆或者有关支付确认的界面,经常会用到验证码,验证码有的是通过手机发送获取的,有的是在本地点击获取的,通过手机发送获取的动态验证码可以使用第三方类库实现,本地点击获取的是在本地自己绘制 ...

  8. java 网络编程-tcp/udp

    --转自:http://blog.csdn.net/nyzhl/article/details/1705039 直接把代码写在这里,解释看这里吧:http://blog.csdn.net/nyzhl/ ...

  9. linux下获取ip

    如果打开虚拟机 没有ip置灰显示了 lo 可以使用dhclient自动获取ip 如果想开机就自动获取ip: vim /etc/rc.d/rc.local 在这里插入dhclient命令

  10. 给jdk写注释系列之jdk1.6容器(10)-Stack&Vector源码解析

    前面我们已经接触过几种数据结构了,有数组.链表.Hash表.红黑树(二叉查询树),今天再来看另外一种数据结构:栈.      什么是栈呢,我就不找它具体的定义了,直接举个例子,栈就相当于一个很窄的木桶 ...