用C语言编写一个将8位二进制数转化成BCD码的程序

用C语言编写一个将8位二进制数转化成BCD码的程序,第1张

#define uchar unsigned char

uchar 8_bit;

uchar ge,shi,bai;

bai=8_bit/100;

shi=8_bit%100/10;

ge =8_bit%10;

编程实现两个一字节压缩型BCD码的减法,

设被减数地址在R0中,减数地址在R1中,差仍存于被减数地址单元中。

注意是单片机中啊。

------------------

一字节压缩的 BCD 码相减。

如:22-55 =-33。

注意:-33 的 BCD 补码是 67H。

MCS-51 汇编语言程序如下:

MOV R2,#22H;被减数

MOV R3,#55H;减数

CLR C

MOV A,R2

SUBB  A,R3 ;先减一次,取得正负号

MOV F0,C ;暂时保存

;---------下面正式相减

MOV A,#9AH

SUBB  A,R3 ;求减数的 BCD 补码=45H

ADD A,R2 ;加上被减数 22H,得 67H

DA  A  ;十进制调整,还是 67H

MOV R4,A ;保存差

MOV C,F0 ;用 Cy 当做“符号标志位”

--------------

如果运算数据,是:55-22 = 33,

执行本程序,将有:C = 0,R4 = 33。

一个字节的BCD码就是用一个字节的二进制数表示两位十进制数。

如十进制数96表示成压缩BCD码就是96H,转换成ASCII码就是压缩BCD码表示的十进制数的高位和低位分开,以ASCII码表示,即转换成39H和36H。

汇编语言(AssemblyLanguage)是面向机器的程序设计语言。在汇编语合中,用助记符(Memoni)代替 *** 作码,用地址符号(Symbol)或标号(Label)代替地址码。这样用符号代替机器语言的二进制码,就把机器语言变成了汇编语言。于是汇编语言亦称为符号语言。使用汇编语言编写的程序,机器不能直接识别,要由一种程序将汇编语言翻译成机器语言,这种起翻译作用的程序叫汇编程序,汇编程序是系统软件中语言处理系统软件。汇编程序把汇编语言翻译成机器语言的过程称为汇编。中国著名计算机科学教育家王爽写过一本名叫《汇编语言》的书。

#include <stdioh>

#include <stdlibh>

#include <stringh>

#define INPUT_BCD_MAX_LENGTH 10

int main(void)

{

    //

    char bcd[ INPUT_BCD_MAX_LENGTH ];

    char bin = NULL;

    char t_bin[ 6 ];

    int i, j, q, r, t, bcd_len, bin_len;

    printf( "Please enter the decimal code: " );

    scanf("%s", bcd);

    

    bcd_len = strlen( bcd );

    bin_len = bcd_len  6 + 1;

    bin = ( char  )malloc( bin_len );

    memset( bin, 0, bcd_len  6 + 1 );

    for( i = 0; i < bcd_len; i++ )

    {

        / 把字符转换为数字/

        q = bcd[ i ] - '0';

        //将每个十进制转换为四位二进制

        for( j = 0; j < 4; j++ )

        {

            t = q / 2;

            r = q % 2;

            q = t;

            if( q == 0 && r != 1 )

            {

                t_bin[ j ] = '0';

            }

            else

            {

                //把数字转换为字符

                t_bin[ j ] = r + '0';

            }

        }

        t_bin[ j ] = ' ';

        t_bin[ j + 1 ] = '\0';

        strrev( t_bin );

        strcat( bin, t_bin );

    }

 

    printf( "BCD coded decimal:\n%s\n", bin );

    free( bin );

    bin = NULL;

 

    system("pause");

    return 0;

}

方法:

1、把2000H赋值给2001H,即(2001H)=(2000H),

2、2000H与0FH逻辑“与”运算,得低4位;

3、2001H高、低半字节交换,

4、2001H与0FH逻辑“与”运算,得高4位。

MOV R0, TH1

MOV R1, TL1

CALL HEX2BCD ;调用子程序把R0 R1中的数字,转换成BCD码,送到R2 R3 R4

;-------下面,把万千百十个位,分别存入R4 R3 R2 R1 R0

MOV A, R4

MOV B, #16

DIV AB ;除以16,目的是分离出高、低四位

MOV R1, A ;存放十位

MOV R0, B ;存放个位

;

MOV A, R2

MOV R4, A ;存放万位

;

MOV A, R3

MOV B, #16

DIV AB

MOV R3, A

MOV R2, B

SJMP $ ;到此,完成了题目要求

;------------------------------------------------------------------

;两个字节的二进制数转换成BCD码的程序如下:

;功能:16位二进制数变换成为 BCD 码;

;入口:R0 R1 中是 16 位二进制数,其中R0中是高 8 位;

;出口:R2 R3 R4 中是 BCD 码,其中R2中是万位,R3中是千、百位,R4中是十、个位。

HEX2BCD:

CLR A

MOV R2, A ;先清零

MOV R3, A

MOV R4, A

MOV R5, #16 ;共转换十六位数

LOOP:

CLR C

MOV A, R1 ;从待转换数的高端移出一位到Cy

RLC A

MOV R1, A

MOV A, R0

RLC A

MOV R0, A

MOV A, R4 ;送到BCD码的低端

ADDC A, R4 ;带进位加。自身相加,相当于左移一位

DA A ;十进制调整,变成BCD码

MOV R4, A

MOV A, R3

ADDC A, R3

DA A

MOV R3, A

MOV A, R2

ADDC A, R2

MOV R2, A

DJNZ R5, LOOP ;共转换十六位数

RET

以上回答你满意么?

即BCD代码。Binary-Coded Decimal�6�0,简称BCD,称BCD码或二-十进制代码,亦称二进码十进数。是一种二进制的数字编码形式,用二进制编码的十进制代码。这种编码形式利用了四个位元来储存一个十进制的数码,使二进制和十进制之间的转换得以快捷的进行。这种编码技巧,最常用于会计系统的设计里,因为会计制度经常需要对很长的数字串作准确的计算。相对于一般的浮点式记数法,采用BCD码,既可保存数值的精确度,又可免却使电脑作浮点运算时所耗费的时间。此外,对于其他需要高精确度的计算,BCD编码亦很常用。

由于十进制数共有0、1、2、…、9十个数码,因此,至少需要4位二进制码来表示1位十进制数。4位二进制码共有2^4=16种码组,在这16种代码中,可以任选10种来表示10个十进制数码,共有N=16!/(16-10)!约等于29乘以10的10次方种方案。常用的BCD代码列于末。

常用BCD编码方式

最常用的BCD编码,就是使用"0"至"9"这十个数值的二进码来表示。这种编码方式,在中国大陆称之为“8421码”。除此以外,对应不同需求,各人亦开发了不同的编码方法,以适应不同的需求。这些编码,大致可以分成有权码和无权码两种:

有权BCD码,如:8421(最常用)、2421、5421…

无权BCD码,如:余3码、格雷码…

以下为三种常见的BCD编码的比较。

十进数 8421-BCD码 余3-BCD码 2421-A码

(M10) D C B A C3 C2 C1 C0 a3 a2 a1 a0

0 0 0 0 0 0 0 1 1 0 0 0 0

1 0 0 0 1 0 1 0 0 0 0 0 1

2 0 0 1 0 0 1 0 1 0 0 1 0

3 0 0 1 1 0 1 1 0 0 0 1 1

4 0 1 0 0 0 1 1 1 0 1 0 0

5 0 1 0 1 1 0 0 0 0 1 0 1

6 0 1 1 0 1 0 0 1 0 1 1 0

7 0 1 1 1 1 0 1 0 0 1 1 1

8 1 0 0 0 1 0 1 1 1 1 1 0

9 1 0 0 1 1 1 0 0 1 1 1 1

常用BCD码

十进制数 8421码 5421码 2421码 余3码 余3循环码

0 0000 0000 0000 0011 0010

1 0001 0001 0001 0100 0110

2 0010 0010 0010 0101 0111

3 0011 0011 0011 0110 0101

4 0100 0100 0100 0111 0100

5 0101 1000 1011 1000 1100

6 0110 1001 1100 1001 1101

7 0111 1010 1101 1010 1111

8 1000 1011 1110 1011 1110

9 1001 1100 1111 1100 1010

什么是BCD码2006-3-19 13:24:45

bcd码也叫8421码就是将十进制的数以8421的形式展开成二进制,大家知道十进制是0~9十个数组成,着十个数每个数都有自己的8421码:

0=0000

1=0001

2=0010

3=0011

4=0100

5=0101

6=0110

7=0111

8=1000

9=1001

举个例子:

321的8421码就是

3 2 1

0011 0010 0001

具体:

bcd码是十位二进制码, 也就是将十进制的数字转化为二进制, 但是和普通的转化有一点不同, 每一个十进制的数字0-9都对应着一个四位的二进制码,对应关系如下: 十进制0 对应 二进制0000 ;十进制1 对应二进制0001 9 1001 接下来的10就有两个上述的码来表示 10 表示为00010000 也就是BCD码是遇见1001就产生进位,不象普通的二进制码,到1111才产生进位10000

举例:

某二进制无符号数11101010,转换为三位非压缩BCD数,按百位、十位和个位的顺序表示,应为<U>__C</U>__。

A00000001 00000011 00000111B 00000011 00000001 00000111

C00000010 00000011 00000100D 00000011 00000001 00001001

解:(1)11101010转换为十进制:234

(2)按百位、十位和个位的顺序表示,应为<U>__C</U>__。

附注:压缩BCD码与非压缩BCD码的区别—— 压缩BCD码的每一位用4位二进制表示,一个字节表示两位十进制数。例如10010110B表示十进制数96D;非压缩BCD码用1个字节表示一位十进制数,高四位总是0000,低4位的0000~1001表示0~9例如00001000B表示十进制数8

以上就是关于用C语言编写一个将8位二进制数转化成BCD码的程序全部的内容,包括:用C语言编写一个将8位二进制数转化成BCD码的程序、单片机msc-51中编程实现两个一字节压缩型BCD码的减法、如何用汇编语言将BCD码96H转换成2个字节的ASCII码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9807276.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存