[POJ1220]NUMBER BASE CONVERSION (高精,进制转换)

任意进制之间的高进的转换

思路

相模倒排,高精处理

代码

我太弱了,下面附一个讨论里发的maigo思路的代码

int i,l,k,a,b,T,t[555],A[555];
char s[555],d[555];
main(){

    for(scanf("%d",&T);T--;){
        scanf("%d%d%s",&a,&b,s);

        for(k=i=strlen(s);0<i--;)t[k-1-i]=s[i]-(s[i]<58?48:s[i]<97?55:61);

        for(l=0;k;){
            for(i=k;1<i--;){
                t[i-1]+=t[i]%b*a;
                t[i]/=b;
            }
            A[l++]=t[0]%b;
            t[0]/=b;
            for(;0<k&&!t[k-1];k--);
        }

        for(d[l]=i=0;i<l;i++)d[l-1-i]=A[i]+(A[i]<10?48:A[i]<36?55:61);

        printf("%d %s\n%d %s\n\n",a,s,b,d);
    }

}

 

相关文章:

  • 2022-01-01
  • 2022-02-21
  • 2021-12-12
  • 2021-10-18
  • 2021-10-08
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-02-17
  • 2022-12-23
  • 2022-02-20
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-11-23
相关资源
相似解决方案