BCD转换成十进制
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); }
當然,方法不只一種,以下代碼也可以實現:
int BCDToInt(byte bcd) //BCD轉十進制 {return (0xff & (bcd>>4))*10 +(0xf & bcd); }int IntToBCD(byte int) //十進制轉BCD { return ((int/10)<<4+((int%10)&0x0f); }總結
- 上一篇: 举个栗子~Tableau 技巧(216)
- 下一篇: 嵌入式的技术竞争力