基数排序 - 次位优先算法

Posted 张乐乐章

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基数排序 - 次位优先算法相关的知识,希望对你有一定的参考价值。

算法描述

多关键字排序:

技术分享技术分享

又比如123,主位是1,次卫是3。

123,46,791。 按照次位优先     次位:791,123,46

                                         次次位:123,46,791

                                      次次次位:46,123,791

具体实现

建立桶元素结点,用链表实现。

建立桶头尾结点结构体。

构造GetDigit ( int X, int D )函数 用来得到X的D位的数字

构造LSDRadixSort( ElementType A[], int N )

 {

      初始化每个桶为空链表

      将原始序列逆序存入初始链表List

      排序

      {  

               对数据的每一位循环处理

               {

                 获得当前元素的当前位数字 

                 从List中摘除

                 插入B[Di]号桶尾

               }

       }

      收集(将每个桶的元素顺序收集入      将List倒入A[]并释放

 1 #define MaxDigit 4
 2 #define Radix 10
 3 typedef struct Node *PtrToNode;
 4 struct Node
 5 {
 6     int key;
 7     PtrToNode Next;    
 8 };
 9 //定义桶头节点
10 struct HeadNode
11 {
12     PtrToNode head;
13     PtrToNode tail;
14 };
15 typedef struct HeadNode Bucket[Radix];
16 /*
17    X是所求的数,X是几位数 D就是几
18 */
19 int GetDigital(int X,int D)
20 {
21     int i,d;                 //d为返回值,是X在某位上的具体数
22     for(i=1;i<=D;i++)
23     {
24         d=X%Radix;             //Radix =10;
25         X/=Radix;             //Radix =10;
26     }
27     return d;
28 }
29 void LSDRadixSort(ElementType A[],int N)
30 {
31     Bucket B;
32     int i ,D,Di;
33     PtrToNode P,temp,list=NULL;
34 
35     /*初始化桶*/
36     for(i=0;i<Radix;i++)
37    
38         B[i].head=B[i].tail=NULL;
39     
40    /*将数组逆序导入链表list*/
41     for(i=0;i<N;i++)
42     {
43         temp=(PtrToNode)malloc(sizeof( struct Node));  //新建temp
44         temp->key=A[i];     
45         temp->Next=list;    // 第一次temp为list list为null
46         list=temp;          //更新list 为temp
47     }
48     
49     /*从最低位开始入桶*/
50 
51     for(D=1;D<=MaxDigit;D++)
52     {    
53         P=list;
54         while(P)
55         {
56             Di=GetDigital(P->key,D);
57             /*获取位数*/
58             temp=P;
59             P=P->Next;
60             temp->Next=NULL;
61             /*从list中摘除*/
62             if(B[Di].head==NULL)
63                 B[Di].head=B[Di].tail=temp;
64             else
65             {
66                 B[Di].tail->Next=temp;
67                 B[Di].tail=temp;
68             }
69         }
70     
71     /*收集*/
72         list=NULL;
73         for(Di=Radix-1;Di>=0;Di--)
74         {
75             if(B[Di].head)
76             {
77                 B[Di].tail->Next=list;
78                 list=B[Di].head;
79                 B[Di].head=B[Di].tail=NULL;//清空桶
80             }
81         }
82     }
83     /* 将list倒入A[]并释放空间 */
84     for(i=0;i<N;i++)
85     {
86         temp=list;
87         list=list->Next;
88         A[i]=temp->key;
89     //    printf(" i: %d  a: %d   ",i,A[i]);
90         free(temp);
91     }
92 }

 

 

 错误分析:1.将82行的{  放在了70行。

以上是关于基数排序 - 次位优先算法的主要内容,如果未能解决你的问题,请参考以下文章

基数排序

基数排序

十大排序算法之基数排序

每日一算法|基数排序---第十一天

Day5-基数排序和最后单词的长度

排序算法——基数排序