PTA_基础编程题目集_7-4 BCD解密 (10 分)_C语言实现

  1. BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。
   _ _ _ _ _ _ _ _ + _ _ _ _
每四个比特表示一位 一个字节来表达两位~十进制的数

     2.一个BCD数的十六进制是0x12

即 原始BCD:0001 0010; 解读BCD~十六进制:0x12; 解读BCD~十进制:12

误认BCD为2进制~十六进制:0x12(值正确);误认BCD为2进制~十进制:18(错误)

     3.你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。(输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。)

私以为这里的描述和提示把情况说得更加难以理解了,本质上我只需要把错误解读出的十进制二进制后再用正确方式解读即可。

  • 我的代码:
#include<stdio.h>
#include<math.h>

int main()
{
	int num;
	scanf("%d", &num);
	int a[8] = { 0 };
	for (int i=0;num >= 1;i++)
	{//10进制(错误答案)转为2进制
		a[i] = num % 2;
		num /= 2;
	}

	int sd = 0;//正确解读个位
	for (int i = 0; i<4; i++)
		if(a[i])
			sd += pow(2, i);

	int ten = 0;//正确解读十位
	for (int i = 4; i < 8; i++)
		if (a[i])
			ten += pow(2, i-4);

	if(ten==0)
	  printf("%d", sd);

	else
	  printf("%d%d", ten, sd);	  
	  
	return 0;
}
 
 
 

猜你喜欢

转载自blog.csdn.net/qq_43269246/article/details/83687577