radix_sort 淩亂°似流年 2021-10-01 07:48 302阅读 0赞 **基数排序:** **这里还要注意负数的输入,解决方法想了两种:一是把最小数找出来,然后每个数都加一次。** ** 二是将正负数分开排序。** 1 #include<Stdio.h> 2 void radix_sort(int a[],int n); 3 int main(){ 4 int a[100],n; 5 int i; 6 scanf("%d",&n); 7 for( i=0; i<n; i++) 8 scanf("%d",&a[i]); 9 radix_sort(a,n); 10 for( i=0; i<n; i++){ 11 printf("%d ",a[i]); 12 } 13 printf("\n"); 14 return 0; 15 } 16 17 void radix_sort(int a[],int n){ 18 int count_a[10],sort_a[100]; 19 int i,j,k=1; 20 int radix=10; 21 while(1){ 22 for( i=0; i<radix; i++){ 23 count_a[i] = 0; 24 } 25 for( i=0; i<n; i++){ 26 count_a[(a[i]/k)%radix]++;//(a[i]/k)%radix求出最低位的数值 27 } 28 if(n == count_a[0])//结束条件是所有的数的余10都等于0时 29 break; 30 for( i=1; i<10; i++){ 31 count_a[i] = count_a[i]+count_a[i-1]; 32 } 33 for( i=n-1; i>=0; i--){ 34 sort_a[count_a[(a[i]/k)%radix]-1] = a[i];//从末尾开始读数有利于数的稳定性 35 count_a[(a[i]/k)%radix]--; 36 } 37 for( i=0; i<n; i++){ //更新排序 38 a[i] = sort_a[i]; 39 } 40 k *= radix; 41 for( i=0; i<n; i++){ 42 printf("%d ",sort_a[i]); 43 } 44 printf("\n"); 45 printf("k=%d\n",k); 46 } 47 48 } ![924293-20170326201927674-286705965.png][] 转载于:https://www.cnblogs.com/lpa1027/p/6623892.html [924293-20170326201927674-286705965.png]: /images/20210724/c5af7d2e35a14c29b0e1e108e38911ae.png
相关 Java实现算法 java实现基数排序 RadixSort 其实就是个十百千万位...每位数去计数排序 建议先看计数排序 public class RadixSort { public static voi 短命女/ 2022年11月30日 12:34/ 0 赞/ 199 阅读
相关 JavaScript实现RadixSort基数排序算法(附完整源码) JavaScript实现RadixSort基数排序算法(附完整源码) Comparator.js完整源代码 Sort.js完整源代码 RadixSort r囧r小猫/ 2022年09月07日 09:56/ 0 赞/ 168 阅读
相关 内部排序之基数排序(RadixSort) 一、基本思想 > 基数排序借助的多关键字进行排序的思想对单逻辑关键字进行排序。 > ![这里写图片描述][20160927121020968] 二、链式基数排序 男娘i/ 2021年06月10日 20:42/ 0 赞/ 383 阅读
还没有评论,来说两句吧...