精华内容
下载资源
问答
  • 实现十进制与压缩bcd码之间的转换

    千次阅读 2014-11-13 10:12:16
    #include #include #include int Dec2BCD(int data) {  int i=data,j=0,k=0;  int sum=0;  while(1)  {  j = i%10;  i = i/10;  sum = sum+(j  k++;  
    </pre><pre name="code" class="cpp">#include <stdio.h>
    #include <stdlib.h>
    #include <Math.h>
    int Dec2BCD(int data)
    {
        int  i=data,j=0,k=0;
        int sum=0;
        while(1)
        {
            j = i%10;
            i = i/10;
            sum = sum+(j<<4*k);
            k++;
            if(i==0)break;
        }
        return sum;
    }
    int BCD2Dec(int data)
    {
       int k=0,sum=0;
       while(data>0)
       {
           sum += ceil(pow(10,k))*(data&0xf);
           data=data>>4;
           k++;
       }
       return sum;
    }
    
    int main()
     {
        printf("Hello world!\n");
        printf("Dec2BCD the sum is %x\n",Dec2BCD(0x3f));
        printf("BCD2Dec the sum is %x\n",BCD2Dec(0x18));
        int i=0;
        for(;i<65536;i++)
        {
            Dec2BCD(i);
            if(i!=BCD2Dec(Dec2BCD(i)))
            {
                printf("!=\n");
    
                break;
            }
        }
     printf("i is %d\n",i);
        return 0;
    }
    


    展开全文
  • BCD码与十进制数间转换

    千次阅读 2020-05-26 20:25:47
      BCD码(Binary-Coded Decimal‎)称为二进码十进或二——十进制代码。用4位二进制来表示1位十进制数中的0~9这10个数码。BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最...

    一、前言:

    这几天在项目协议对接的时候有一部分功能是获取系统时间功能与校时功能。小马哥获取到时间后打印了一下 2020-5-26 20:06:32,一看时间是对的,然后美滋滋的组装协议发送平台测试了。测试的时候发现月、日、时分秒数据都正常,就是2020年显示的是一个三万多的一个数,此事必有蹊跷。

    能打印出正确时间但是平台显示的是错误数据只有两个原因。一个是获取到时间后协议封装有问题,另一个是平台解析有问题。出现问题肯定是要先查自己部分看看是不是自己埋了个bug了。

    查了几分钟发现是小马哥开始看协议的时候粗心了,数据类型是BCD码(当初看到BCD的时候还想了一下BCD码是个什么东西,后面忘了。。。)。之前就大学的时候接触过BCD码,好久不用已经忘了BCD码的概念,然后就上网查了一些资料,将时间进行转换,平台可以正确读取时间数据了
    在这里插入图片描述

    BCD码概念

    BCD码(Binary-Coded Decimal‎)称为二进码十进数或二——十进制代码。用4位二进制数来表示1位十进制数中的0~9这10个数码。BCD码可分为有权码和无权码两类:有权BCD码有8421码、2421码、5421码,其中8421码是最常用的BCD码。无权BCD码有余3码,余3循环码等。

    1. 8421码

    8421 BCD码是最基本和最常用的BCD码,它和四位自然二进制码相似,各位的权值为8、4、2、1,故称为有权BCD码。和四位自然二进制码不同的是,它只选用了四位二进制码中前10组代码,即用0000~1001分别代表它所对应的十进制数,余下的六组代码不用。如十进制数8的BCD码是1000。

    2. 5421码

    5421 BCD码是有权BCD码,从高位到低位的权值分别为5、4、2、1。

    3. 2421码

    2421 BCD码为有权BCD码,从高位到低位的权值分别为2、4、2、1。

    4. 余3码

    余3码是8421 BCD码的每个码组加3(0011)形成的。常用于BCD码的运算电路中。

    三、BCD 码应用场合

    BCD码目前最常使用的应该是时钟芯片中,从时钟芯片中获取的时间数据即是BCD码格式,需要程序员将其转换为十进制数据。其他应用场合还包括,PLC控制输入、拨码开关输入、数码管控制等。

    四、.BCD 码与十进制间转换

    下面是8421码与是十进制间的相互转换代码,亲测可用:

    1. 8421码转十进制数

    如,从时钟芯片中读出的时间数据,需转换为十进制数。

    unsigned char bcd_to_hex(unsigned char data)
    {
        unsigned char temp;
    
        temp = ((data>>4)*10 + (data&0x0f));
        return temp;
    }
    

    2. 十进制数转8421码

    如,往时钟芯片写入数据时,需将待写的十进制数转换为8421码。

    unsigned char hex_to_bcd(unsigned char data)
    {
        unsigned char temp;
    
        temp = (((data/10)<<4) + (data%10));
        return temp;
    }
    

    相关BCD码资料链接:https://blog.csdn.net/zhouzx9293/article/details/82182599

    展开全文
  • 【计算机组成原理】十进制数

    千次阅读 2020-05-02 15:09:38
    2.(重点)压缩十进制数串形式(BCD码) 一个字节存放两个十进制数位,符号位和位都各占半个字节,符号位放于最低数字位之后。 其值选用四位编码的冗余状态,先比于第一种方法,更便于直接完成十进制数的计算。 ...

    表示方法

    1.字符串形式(用于非数值计算)
    一个字节存放一个十进制的数位或者是符号位
    2.(重点)压缩的十进制数串形式(BCD码)
    一个字节存放两个十进制数位,符号位和数位都各占半个字节,符号位放于最低数字位之后。
    其值选用四位编码的冗余状态,先比于第一种方法,更便于直接完成十进制数的计算。

    可以用1216进制中的C)表示正号,用1316进制中的D)表示正号
    
    > 数位+符号位=偶数(如果不是偶数,就在最高位之前补一个0



    举例实操:
    在这里插入图片描述

    展开全文
  • BCD码和十进制数和十六进制关系

    千次阅读 2020-02-22 10:37:22
    //先将4个字节的BCD码分别转换为十进制,按照十进制数的整合方式整合为长整形   ucHEXdata[0] = (ucBCDdata[0]>>4)*10 +(0xf & ucBCDdata[0]); ucHEXdata[1] = (ucBCDdata[1]>>4)*10 +(0xf & ucBCDdata[1]...
    1. unsigned char ucBCDdata[10] = {0x11,0x22,0x33,0x44,0x55,0x55,0x66,0x77};
    2. unsigned char ucHEXdata11 = 0,ucHEXdata[10] = {0};
    3. unsigned int uiHEXdata = 0,uiHEXdata11 = 0;
    4. unsigned long int ulHEXdata = 0;
    5. BCD码和十进制数互转的函数,BCD码和十六进制数互转的函数是不同的。因为十六进制数和十进制数还要互转呢。十六进制数有ABCDEF表示,十进制数没有。所以不同。看你需要的什么类型进制数据,只不过BCD码借用了十六进制数据的表示形式,但和十六进制也是不同的,BCD码逢十进一,且没有ABCDEF数字(字母)符号

     

    1. //1、现实中十六进制数和十进制数不可以直接相加,如果是在电脑上的话是可以的,因为不管
    2. //何种进制数在电脑上都是以二进制的形式表示的,所以在电脑编写程序时是可以相加的。
    3.  
    4. //C语言程序中,十进制和十六进制实际是互通的,

     

     

    1.  
    2. //单字节BCD码转十进制
    3. //高半字节=BCD码字节除16的商,低半字节=BCD码字节除16的余数
    4.  
    5. ucHEXdata[0] = (ucBCDdata[0]>>4)*10 +(0xf & ucBCDdata[0]);
    6. ucHEXdata11 = ucHEXdata[0];
    7.  
    8. //2字节BCD码转换为整数
    9. //先将2个字节的BCD码分别转换为十进制,然后高字节*100+低字节=整数
    10.  
    11. ucHEXdata[0] = (ucBCDdata[0]>>4)*10 +(0xf & ucBCDdata[0]);
    12. ucHEXdata[1] = (ucBCDdata[1]>>4)*10 +(0xf & ucBCDdata[1]);
    13. uiHEXdata = ucHEXdata[1]*100 + ucHEXdata[0];
    14.  
    15. //4字节BCD码转换为整数
    16. //先将4个字节的BCD码分别转换为十进制,按照十进制数的整合方式整合为长整形
    17.  
    18. ucHEXdata[0] = (ucBCDdata[0]>>4)*10 +(0xf & ucBCDdata[0]);
    19. ucHEXdata[1] = (ucBCDdata[1]>>4)*10 +(0xf & ucBCDdata[1]);
    20. ucHEXdata[2] = (ucBCDdata[2]>>4)*10 +(0xf & ucBCDdata[2]);
    21. ucHEXdata[3] = (ucBCDdata[3]>>4)*10 +(0xf & ucBCDdata[3]);
    22. ulHEXdata = ((unsigned long int)ucHEXdata[3]*1000000)
    23. +((unsigned long int)ucHEXdata[2]*10000)
    24. +((unsigned long int)ucHEXdata[1]*100) + ucHEXdata[0];
    展开全文
  • 单片机简单的编程题目,编写10位十进制加法子程序(十进制数采用压缩BCD码存放)入口:加:24H-20H,低地址放低字节; 加:29H-25H,低地址放低字节;出口:和数:24H-20H,低地址放低字节。才学习!实在是...
  • 十进制转成十六进制:Integer.toHexString(int i)十进制转成八进制Integer.toOctalString(int i) 十进制转成二进制Integer.toBinaryString(int i)十六进制转成十进制Integer.valueOf("FFFF",16).toString...
  • 十六进制 简单的二进制将十进制数转换为十六进制,十进制和二进制。 下载并解压缩后,运行make命令。 $使 要仅清理.o文件,请输入make clean。 $使干净
  • 文章目录数据数值数据的表示方法定点的表示方法浮点数的表示方法例子 数据 数值数据的表示方法 定点格式:计算机中所有数据的小数点位置是固定不变的,数值范围有限 浮点格式:小数点的位置随阶码的位置同步而...
  • 从键盘输入五位十进制数的ASCⅡ码,存放于3500h其实的内存单元中,将其转换为BCD码后,再按位分别存入350Ah起始的内存单元内。若输入的不是十进制ASCⅡ码,则对应存放结果的单元内容为FF。 代码 .model small ....
  • 十进制数转8421BCD码

    千次阅读 2020-05-25 14:35:23
    十进制数转8421BCD码 设计代码 `timescale 1ns / 1ps ////////////////////////////////////////////////////////////////////////////////// // Company: // Engineer: // // Create Date: 11:24:48 04/03/2020 // ...
  • 压缩十进制实例 ;演示十进制加法 include irvine32.inc .data packed_1 WORD 4536h packed_2 WORD 7270h sum DWORD ? .code main PROC ;初始化和属索引 mov sum,0 mov esi,0 ;低字节相加 mov ...
  • 十六进制转十进制和BCD算法(汇编)是应wahllfok的要求上传的,wahllfok原本需要BCD转十六进制的算法,我最近有点忙...这个算法分两个子程序,一个是将十六进制转十进制压缩BCD),一个是BCD解压缩算法。连起来即可。
  • 键盘输入任意位十进制数,分别转换成十六进制、BCD码,并显示对应结果 输出如下 代码如下: STACK1 SEGMENT STACK DW 256 DUP(?) STACK1 ENDS DDATA SEGMENT MES1 DB 0ah,0dh,'The BCD code of decimal are:$' ...
  • 想到往高进制转换,从而达到压缩的目的,项目中也实现了需求,但后来整理压缩代码时发现,一个很大的转换成高进制后,和在线进制转换工具转换的不一样,但是用下面的方法,十进制转成高进制后,再用高进制把转换...
  • 将两个多位十进制数相减,要求被减数,减数均以 ASCII码形式按顺序存放在以DATA1和DATA2为首的5个内存单元中(低位在前),结果送回DATA1处。 1.这个程序就是实现两个多位相减功能,经过查阅资料分析得到,有两种...
  • 从键盘输入两位十六进制,转化成十进制输出 示例: 输入:10 输出:16 输入:ed 输出:237 输入:egd 输出:237 题目分解 首先我们需要从键盘输入两个16进制,思考两个十六进制该如何写入;其次,我们要将...
  • 在ASCII码中,0到10的二进制分别表示如下。 而BCD码中,0-9的每位仍用一个字节...大家都知道在计算机中,数据的常用编码格式有二进制、八进制、十进制和十六进制等,这些编码格式之间可以相互转换。在电力通信协议...
  • 一个JavaScript库,用于任意精度的十进制非十进制算术。 产品特点 整数和小数 简单的API,但功能齐全 比Java的BigDecimalJavaScript版本更快,更小,甚至更容易使用 缩小并压缩8 KB 复制JavaScript的Number类型的...
  • 实验四 ASCII码表示的十进制数、二进制和BCD的互换编程实验 更多微机实验:https://blog.csdn.net/yxp189/column/info/39992 汇编语言-微机原理接口技术-实验 注意:未经允许,请勿转载! 转载请标明...
  • 汇编 十进制乘法

    2011-12-14 22:06:06
    一个普通的汇编程,用以实现(以4位为例)压缩BCD的乘法(以9为例)
  • 十进制与BCD码转换的算法 BCD码 BCD是指用二进制来表示十进制数的编码,即用4位二进制来表示一位十进制数,因此4位二进制表示最大的十进制数9(1001),只取十六个中的十个。 比如: $$ BCD码:0x99(153),该...
  • BCD码与十进制转化

    千次阅读 2020-06-13 18:35:40
    BCD码(binary-coded Decimal),用4位二进制来表示1位十进制数中的0~9这10个数码,是一种二进制的数字编码形式,用二进制编码的十进制代码。BCD码这种编码形式利用了四个位元来存储一个十进制的数码,使二进制和...
  • STACK1 SEGMENT STACK  DW 256 DUP(?) STACK1 ENDS DATA SEGMENT  BUF DB 30H,30H,31H,32H DATA ENDS CODE SEGMENT  ASSUME CS:CODE,DS:DATA START:MOV AX,DATA  MOV DS,AX  MOV SI,OFFSET...
  • cout 请输入一个十进制的任意实数" ; float x; cin >> x; tran_b_hex(x);//主转换函数 return 0; }   ---yyz 2018.11.4 转载于:https://www.cnblogs.com/likeghee/p/9906416.html
  • Balanced Numbers-位dp-三进制状态压缩 Balanced Numbers-位dp-三进制状态压缩 Description Input Output Examples Input Ouput Problem Description Solution Code Description Balanced ...
  • C# BCD码与十进制数的转换

    千次阅读 2017-10-09 15:37:16
    BCD码(Binary-Coded Decimal‎)是二进制编码的十进制数的缩写,BCD码用4位二进制表示一位十进制数。BCD码各位的数值范围为2#0000~2#1001,对应于十进制数0~9。BCD码不能使用十六进制的A~F(2#1010~2#1111)这...
  • 赫夫曼树基本介绍 1、给定n个权值作为n个叶子结点,构造一棵二叉树,若该树的带权路径长度(wpl)达到最小,称这样的二叉树为最优二叉树,...若规定根结点的层为1,则从根结点到第L层结点的路径长度为L-1 2、结点的权
  • 编写子程序Bin2BCD、BCD2Bin实现二进制数压缩BCD码的相互转换。待转换的二进制数存放在w寄存器内,子程序调用完成后得到的BCD码仍存放在w寄存器内返回。例如: movlw .45 ; w=45 call Bin2BCD ; nop ; w=0x45...
  • 例如0x23和0x45 转化成 十进制4523 2:实现 /******************************************************************************* * @file pow.c * @verison v1.0.0 * @copyright COPYRIGHT &copy; 2020 CSG ...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 63,634
精华内容 25,453
关键字:

十进制数的压缩与非压缩