版权声明:本文为CSDN博主「ZooRyan」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/github_36248956/article/details/56300707
BCD码是指用二进制来表示十进制数的编码,即用4位二进制来表示一位十进制数,因此4位二进制数表示最大的十进制数9(1001),只取十六个数中的十个数(有别于8421码)。
为了表示两个十进制数(十位、个位),需要两个BCD码(8位),可以用char 类型来储存,比如:
BCD码:0x99 (153),共八位,储存在char 类型中,它对应的二进制为1001 1001.
该BCD码要转换成十进制数99。
思路:十进制数逢十进一,而十六进制逢十六进一,它们之间每次进位差了6,这就是十六进制与十进制数的本质区别,因此要把一个BCD转换成一个十进制的数,先要算清多进位了几次,比如0x99,它多进位9次,那它就多加了9次6,要转换成十进制,只需用0x99 - 9*6 即可。
所以,我比较中意的算法就是
153 - 99= 54
54 / 9 = 6
static unsigned char bcd_decimal(unsigned char bcd)
{
return bcd-(bcd >> 4)*6;
}
static unsigned char decimal_bcd(unsigned char decimal)
{
return (unsigned char) (decimal+(decimal / 10)*6);
}