Chinaunix首页 | 论坛 | 博客
  • 博客访问: 39950
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 14:05:04

2009-03-24 16:16

void RadixSort(int Num[],int N,int d){
     int radix = 1;
     int i,j;
    
     for(i=0;i<d;i++){
         CountingSort(Num,N,radix);
         radix *= BASE;
     }
}
   
void CountingSort(int Num[],int N,int d){
     int i,j;
  
     memset(C,0,sizeof(C) );
     for(i=1;i<=N;i++)
         C[GetBit(Num[i],d) ]++;
   
     for(i=1;i<10;i++)
         C[i] += C[i-1];
       
     for(i=N;i>=1;i--){
         R[C[GetBit(Num[i],d) ] ]=Num[i];
         C[GetBit(Num[i],d) ]--;
     }
    
     for(i=1;i<=N;i++)
         Num[i] = R[i];
}

int GetBit(int N,int d){
    return (N/d)%10;
}


阅读(201) | 评论(0) | 转发(0) |
0

上一篇:计数排序

下一篇:开放寻址法的几种实现

给主人留下些什么吧!~~