gpt4 book ai didi

C语言:十进制,BCD码互换详解

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 30 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章C语言:十进制,BCD码互换详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

最近写单片机 RTC 日期、时间配置,需要实现十进制、BCD码互换,将示例Demo分享给各位朋友:

C语言:十进制,BCD码互换详解

BCD是指用二进制来表示十进制数的编码,即:用4位二进制来表示一位十进制数,因此4位二进制数表示最大的十进制数9(1001).

一个四位的BCD码不能够表达十进制的两位数,因此当数字大于九时,我们需要用八位BCD码来表示。高位只需要逢九进一即可.

十进制是逢十进一,而十六进制是逢十六进一,它们之间的每次进位差6,所以一个十进制数要转换成BCD码,要先算清多进位的位数.

当两个BCD码相加,如果和等于或小于 1001(即十进制数9),不需要修正.

C语言:十进制,BCD码互换详解

如果相加之和在 1010 到1111(即十六进制数 0AH~0FH)之间,则需加 6 进行修正.

C语言:十进制,BCD码互换详解

例如,十进制99进位了99/10=9次,每次进位和十六进制进位相比差6,所以一共差了9×6=54,即BCD码为:99+54=153(十六进制:0X99)。BCD码转化成十进制码也一样原理.

  。

1、复杂版

十进制转换为BCD码,代码如下所示:

int decimal_bcd_code(int decimal){	int sum = 0;  //sum返回的BCD码	for (int i = 0; decimal > 0; i++)	{		sum |= ((decimal % 10 ) << ( 4*i));		decimal /= 10;	}	return sum;}

BCD码转换为十进制,代码如下所示:

 

int bcd_decimal_code( int bcd){	int sum = 0, c = 1;  // sum返回十进制,c每次翻10倍	for(int i = 1; bcd > 0; i++)	{		if( i >= 2)		{			c*=10;		}		sum += (bcd%16) * c;		bcd /= 16;  // 除以16同理与十进制除10将小数点左移一次,取余16也同理	}	return sum;}

  。

2、简易版

十进制转换为BCD码,代码如下所示:

int bcd_decimal_code( int bcd){  return (bcd + (bcd/10) * 6);}

BCD码转换为十进制,代码如下所示:

int decimal_bcd_code(int decimal){  return (decimal - (decimal>>4) * 6);}

参考资料:

1、十进制与BCD码转换的算法 。

2、十进制转BCD码在线工具 。

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我的更多内容! 。

原文链接:https://blog.csdn.net/m0_38106923/article/details/120000157 。

最后此篇关于C语言:十进制,BCD码互换详解的文章就讲到这里了,如果你想了解更多关于C语言:十进制,BCD码互换详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com