首页 > 代码库 > 进制转换——9018——1065
进制转换——9018——1065
我不知道这算不算数论
暂且归到数论好了,其实我是为了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
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。