杨美人!的博客

世界上所有的不幸,都是当事者能力不足造成的

POJ1220 (任意进制之间的相互转换)

以十进制为中转。

#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<stdlib.h>
#include<string.h>

using namespace std;

int main()
{
    ios::sync_with_stdio(false);cin.tie(0);

    int n;
    scanf("%d",&n);
    char s[1025];
    int f[1025];
    int ans[1025];
    while(n--)
    {
        int a,b;
        scanf("%d%d%s",&a,&b,s);
        printf("%d %s\n%d ",a,s,b);
        int len=strlen(s);
        for(int i=0;i<len;i++)
            f[i]=isdigit(s[i])?s[i]-'0':(islower(s[i])?s[i]-'a'+36:s[i]-'A'+10);
        int j=0;
        while(len>0)
        {
            int s=0;
            bool flag=false;
            int start=0;
            for(int i=0;i<len;i++)
            {
                s=s*a+f[i];
                if(s/b)
                    flag=true;
                if(flag)
                {
                    f[start++]=s/b;
                    s%=b;
                }
            }
            len=start;
            ans[j++]=s;
        }
        for(int i=j-1;i>=0;i--)
            printf("%c",ans[i]>=36?ans[i]-36+'a':(ans[i]>=10?ans[i]-10+'A':ans[i]+'0'));
        printf("\n\n");
    }
    return 0;
}
阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

POJ1220 (任意进制之间的相互转换)

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭