【数据结构之排序10】基数排序

转载 2013年10月22日 11:11:07
本节介绍第二种分配排序,基数排序(Radix Sort)是对箱排序的改进和推广。

1、单关键字和多关键字

文件中任一记录R[i]的关键字均由d个分量
                      
构成。
若这d个分量中每个分量都是一个独立的关键字,则文件是多关键字的(如扑克牌有两个关键字:点数和花色);否则文件是单关键字的,
                
(0≤j<d)只不过是关键字中其中的一位(如字符串、十进制整数等)。
多关键字中的每个关键字的取值范围一般不同。如扑克牌的花色取值只有4种,而点数则有13种。单关键字中的每位一般取值范围相同。

2、基数

设单关键字的每个分量的取值范围均是:
      C0≤kj≤Crd-1(0≤j<d)
可能的取值个数rd称为基数。
     基数的选择和关键字的分解因关键宇的类型而异:
(1) 若关键字是十进制整数,则按个、十等位进行分解,基数rd=10,C0=0,C9=9,d为最长整数的位数;
(2) 若关键字是小写的英文字符串,则rd=26,Co='a',C25='z',d为字符串的最大长度。

3、基数排序的基本思想

     基数排序的基本思想是:从低位到高位依次对Kj(j=d-1,d-2,…,0)进行箱排序。在d趟箱排序中,所需的箱子数就是基数rd,这就是"基数排序"名称的由来。

4、基数排序的排序过程

     要排序的记录关键字取值范围是0到99之间的整数(36,5,16,98,95,47, 32,36,48)。对这些关键字进行基数排序的过程【参见动画演示】。

5、基数排序的类型说明和算法描述

     要保证基数排序是正确的,就必须保证除第一趟外各趟箱排序是稳定的。

6、算法分析

     若排序文件不是以数组R形式给出,而是以单链表形式给出(此时称为链式的基数排序),则可通过修改出队和人队函数使表示箱子的链队列无须分配结点空间,而使用原链表的结点空间。人队出队操作亦无需移动记录而仅需修改指针。虽然这样一来节省了一定的时间和空间,但算法要复杂得多,且时空复杂度就其数量级而言并未得到改观。
     基数排序的时间是线性的(即O(n))。
     基数排序所需的辅助存储空间为O(n+rd)。

     基数排序是稳定的。


原文地址:http://student.zjzk.cn/course_ware/data_structure/web/main.htm

【数据结构】基数排序的哈希表

  • 2010年08月09日 05:45
  • 23KB
  • 下载

【数据结构】算法10.15-10.17 链式基数排序

#include #include #include#define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEAS...

数据结构基础(15) --基数排序

基数排序是一种借助“多关键字排序”的思想来实现“单关键字排序”的内部排序算法。 实现多关键字排序通常有两种作法:    最低位优先法(LSD)     先对K[0]{基数的最低位}进行排序,并按...

一步一步复习数据结构和算法基础-LSD基数排序

#include #include typedef struct node { int data; struct node *next; }ListNode; typedef struct Arr...

第16周SHH数据结构-【项目1-验证算法(8)基数排序 】

/* * Copyright (c)2015,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:项目1-8.cbp * 作 者:孙...

数据结构基础(15) --基数排序

基数排序是一种借助“多关键字排序”的思想来实现“单关键字排序”的内部排序算法。 实现多关键字排序通常有两种作法:    最低位优先法(LSD)     先对K[0]{基数的最低位}进...

javascript数据结构4-队列2-基数排序

第一次按个位上的数字进行排序,第二次按十位上的数字进行排序 排序:91, 46, 85, 15, 92, 35, 31, 22 经过基数排序第一次扫描之后,数字被分配到如下盒子中:Bin 0: B...

python数据结构学习笔记-2016-11-24-02-基数排序

12.4 基数排序          基数排序(radix sort)是一种只适用于数字或字母类型的排序方法,它检查数字或字母的每一位,将之分类,按照位数的特定顺序,来将元素排列。        ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【数据结构之排序10】基数排序
举报原因:
原因补充:

(最多只允许输入30个字)