每组输入数据共有三行,第一行是一个正整数,表示需要转换的数的进制n(2≤n≤16),
第二行是一个n进制数,若n>10则用大写字母A~F表示数码10~15,并且该n进制数对
应的十进制的值不超过1000000000,第三行也是一个正整数,表示转换之后的数的进制m(2≤m≤16)。
16
FF
2
#include <iostream>
#include <cstring>
#include <stdio.h>
using namespace std;
char out[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
int i,n,m,s;
char num[33];
int main()
{
while(scanf("%d",&n)!=-1)
{
scanf("%s%d",num,&m);
for(s=i=0;i<strlen(num);++i)
if(num[i]>='0'&&num[i]<='9')
s=s*n+num[i]-'0';
else
s=s*n+num[i]-'A'+10;
for(i=0;s>0;s=s/m)
num[i++]=out[s%m];
for(--i;i>=0;--i)putchar(num[i]);
puts("");
}
return 0;
}
本文详细解析了一种高效的进制转换算法,适用于2至16进制之间的转换,包括大写字母A~F表示的10~15数码。通过实例演示了如何将十六进制数转换为二进制数,提供了完整的C++代码实现。
1777

被折叠的 条评论
为什么被折叠?



