一个基数排序(桶子算法)算法的例子

基数算法基本思想:将一个数组先按个位排序,整合一下;再按十位排序。。。。(当然也可以从高位到低位)

该算法时间复杂度约为O(n*数的位数)

#include <stdio.h>   
#include <stdlib.h>   
int main()
{
 int data[10]={73,22,93,43,55,14,28,65,39,81};
 int temp[10][10]={0};  基数排序算法
 int order[10]={0};
  int i,j,k,n,lsd;
  k=0;n=1;
  printf("\n排序前: ");
  for (i=0;i<10;i++)
  printf("%d ",data[i]);
 putchar('\n');
 while(n<=10)
 {
   for (i=0;i<10;i++)
        {
    lsd=((data[i]/n)%10);
    temp[lsd][order[lsd]]=data[i];
    order[lsd]++;
   }
   printf("\n重新排列: ");
   for (i=0;i<10;i++)
        {
       if(order[i]!=0)
       for (j=0;j<order[i];j++)
            {
       data[k]=temp[i][j];
       printf("%d ",data[k]);
       k++;
       }
       order[i]=0;
      }   
        n*=10;
   k=0;
 }
 putchar('\n');
 printf("\n排序后: ");
 for (i=0;i<10;i++)
    printf("%d ",data[i]);
 return 0;   
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值