首页 > 其他 > 详细

进制转换——9018——1065

时间:2017-08-08 22:28:02      阅读:250      评论:0      收藏:0      [点我收藏+]

我不知道这算不算数论

暂且归到数论好了,其实我是为了hash顺便打打的。

#include<cstdio>
#include<cstring>
int p,q,l,num=0,tmp=1,sum;char c[16];
int main()
{
    scanf("%d%d%s",&p,&q,c);l=strlen(c);
    for(int i=l-1;i>=0;i--){
        if(c[i]<=9&&c[i]>=0)num=c[i]-0;
        else num=c[i]-A+10;
        sum+=tmp*num;tmp*=p;
    }
    l=0;
    while(sum){
        tmp=sum%q;sum/=q;
        if(tmp>=0&&tmp<=9)c[l++]=tmp+0;
        else c[l++]=tmp-10+A;
    }
    for(int i=l-1;i>=0;i--)printf("%c",c[i]);
    return 0;
}

本文由Yzyet编写,网址为www.cnblogs.com/Yzyet。非Yzyet同意,禁止转载,侵权者必究。

进制转换——9018——1065

原文:http://www.cnblogs.com/Yzyet/p/7309186.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!