C语言求助,这个函数能有简单点的写法吗?想蒙住了. 求指点.

2020-02-02 09:19发布

目的是用在单片机数码管显示,高位清零,本来的代码能用,但是一个数如果是980,转换后是00000980,就想把高位是零的消掉.这是很笨的办法.所以请教高手能否简化写法.
uint32 定义为 无符号32位整数.


void BCDDataConversion(uint32 Bign)
{


    if (0<=Bign<10){//
    ledcache[7]= leddatacl[Bign%10];   
    ledcache[6]= 0x00;
    ledcache[5]= 0x00;
    ledcache[4]= 0x00;
    ledcache[3]= 0x00;
    ledcache[2]= 0x00;
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    }
    else if (10<=Bign<100){
    ledcache[7]= leddatacl[Bign%10];   
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= 0x00;
    ledcache[4]= 0x00;
    ledcache[3]= 0x00;
    ledcache[2]= 0x00;
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    } else if (100<=Bign<1000){
    ledcache[7]= leddatacl[Bign%10];   
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= 0x00;
    ledcache[3]= 0x00;
    ledcache[2]= 0x00;
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    }else if (1000<=Bign<10000){
    ledcache[7]= leddatacl[Bign%10];        
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= leddatacl[Bign/1000%10];
    ledcache[3]= 0x00;
    ledcache[2]= 0x00;
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    }else if (10000<=Bign<100000){
    ledcache[7]= leddatacl[Bign%10];        
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= leddatacl[Bign/1000%10];
    ledcache[3]= leddatacl[Bign/10000%10];
    ledcache[2]= 0x00;
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    }else if (100000<=Bign<1000000){
    ledcache[7]= leddatacl[Bign%10];   
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= leddatacl[Bign/1000%10];
    ledcache[3]= leddatacl[Bign/10000%10];
    ledcache[2]= leddatacl[Bign/100000%10];
    ledcache[1]= 0x00;
    ledcache[0]= 0x00;
    }else if (1000000<=Bign<10000000){
    ledcache[7]= leddatacl[Bign%10];   
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= leddatacl[Bign/1000%10];
    ledcache[3]= leddatacl[Bign/10000%10];
    ledcache[2]= leddatacl[Bign/100000%10];
    ledcache[1]= leddatacl[Bign/1000000%10];
    ledcache[0]= leddatacl[Bign/10000000%10];
    ledcache[0]= 0x00;
    }else if (10000000<=Bign<100000000){
    ledcache[7]= leddatacl[Bign%10];        
    ledcache[6]= leddatacl[Bign/10%10];
    ledcache[5]= leddatacl[Bign/100%10];
    ledcache[4]= leddatacl[Bign/1000%10];
    ledcache[3]= leddatacl[Bign/10000%10];
    ledcache[2]= leddatacl[Bign/100000%10];
    ledcache[1]= leddatacl[Bign/1000000%10];
    ledcache[0]= leddatacl[Bign/10000000%10];
    }   
    else Bign=0;
}


这个函数能有简单点的写法吗?想蒙住了.  求指点.
补上开发板图片
IMG_20121107_004248_0.jpg (740.3 KB, 下载次数: 0) 下载附件 2012-11-7 00:50 上传
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
28条回答
BXAK
1楼-- · 2020-02-04 19:42
eduhf_123 发表于 2012-11-19 18:44
按照7楼的代码来执行(把代码中赋给 i 的初值由7改为8之后),结果将会是如下两种情况:
参数为0,则8个 ...

随手写的问题就是多
void cccc(uint32 Bign)
{
        unsigned char i,b0,dat;
        
        for (i=8; i; )
        {
                i--;
                ledcache = Bign%10;
                Bign /= 10;
        }                        
   
        for (b=0, i=0; i<8; i++)
        {
                dat = ledcache;
                if (dat || (i==7))  b0=1;                   //有效数开始标志
                if (b0) ledcache = leddatacl[dat];
                else    ledcache = 0xFF;                //有效数之前的 0 消隐
        }            

}
eduhf_123
2楼-- · 2020-02-04 20:27
BXAK 发表于 2012-11-19 23:54
随手写的问题就是多
  1. void cccc(uint32 Bign)
  2. {
  3.         unsigned char i,b0,dat;
  4.         
  5.         for (i=8; i; )
  6.         {
  7.                 i--;
  8.                 ledcache[i] = Bign%10;
  9.                 Bign /= 10;
  10.         }                        
  11.    
  12.         for (b=0, i=0; i<8; i++)
  13.         {
  14.                 dat = ledcache[i];
  15.                 if (dat || (i==7))  b0=1;                   //有效数开始标志
  16.                 if (b0) ledcache[i] = leddatacl[dat];
  17.                 else    ledcache[i] = 0xFF;                //有效数之前的 0 消隐
  18.         }            

  19. }
复制代码


第一个循环中做那么多次的除法和求余操作,可能不是必须的。
longwu537
3楼-- · 2020-02-05 02:14
 精彩回答 2  元偷偷看……
lin33544889
4楼-- · 2020-02-05 03:15
eduhf_123 发表于 2012-11-19 18:35
请注意分析本帖中出现的所有代码,除7楼外任何一楼中所出现的代码都不会把有效位上的“0”给消隐、而只会 ...

嗯 又看了遍
是先消隐,后置位吧,生疏1年就见笑了……

一周热门 更多>