找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

4位16进制数转换为10进制数(8421BCD)求思路

查看数: 3766 | 评论数: 2 | 收藏 0
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2020-3-30 16:03

正文摘要:

如题,在做一道十进制1+2+3+4+……+100的单片机汇编题目,最后要求结果转换为BCD码形式,也就是输出为5050。 我现在是高位低位分开存,利用进位标志符来做的累加(ADDC),最后得到了十六进制输出13BA。现在遇到的 ...

回复

ID:401564 发表于 2020-3-30 20:44
不知道是谁想出来的扯蛋题目
用汇编去转换BCD码干嘛呢?完成运算之后,拆分出来直接显示不就可以了吗?
你这个加法是超过了256的,要用两个地址来存放一个16进制数的
一个16进制数最大数是:65535
在进行BCD码运算中,你要用到三个地址的,结果应该是005050才是,而不是5050
ID:235200 发表于 2020-3-30 18:30
入口条件:待转换的双字节十六进制整数在R6、R7中。
出口信息:转换后的三字节BCD码整数在R3、R4、R5中。
影响资源:PSW、A、R2~R7 堆栈需求: 2字节
HB2: CLR A ;BCD码初始化
MOV R3,A
MOV R4,A
MOV R5,A
MOV R2,#10H ;转换双字节十六进制整数
HB3: MOV A,R7 ;从高端移出待转换数的一位到CY中
RLC A
MOV R7,A
MOV A,R6
RLC A
MOV R6,A
MOV A,R5 ;BCD码带进位自身相加,相当于乘2
ADDC A,R5
DA A ;十进制调整
MOV R5,A
MOV A,R4
ADDC A,R4
DA A
MOV R4,A
MOV A,R3
ADDC A,R3
MOV R3,A ;双字节十六进制数的万位数不超过6,不用调整
DJNZ R2,HB3 ;处理完16bit
RET

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表