分数 10
作者 翁恺
单位 浙江大学
BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!
现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。
输入格式:
输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。
输出格式:
输出对应的十进制数。
输入样例:
18
输出样例:
12
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
// 其实好像就是把十进制的数比如18,转化成十六进制的数如12
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(int argc, char const *argv[])
{
const int X = 16;
// printf("%d\n",50%16);
// printf("%d\n",50/16);
int a = 0, re = 0, b = 0;
scanf("%d", &a);
int i = 0;
for (i = 0; 0 != a; i++)//这里注意循环条件是a≠0,是因为循环体中a正在变化,再判断就是下一次循环的内容了;
{
b = a % X;
a /= X;
re += b * pow(10, i);
}
printf("%d\n", re);
system("pause");
return 0;
}