求一个最节省代码空间的long int转BCD的程序

[复制链接]
4983|13
 楼主| kuyu20 发表于 2010-8-16 12:06 | 显示全部楼层 |阅读模式
20分,求一个最节省代码空间的long int转BCD的程序
aihe 发表于 2010-8-16 12:24 | 显示全部楼层
省代码和要速度是冲突的
给一个我写的仅供参考

//****************************************************
//   hex to bcd 转换程序
//****************************************************
void Hex2Bcd(uint32 num)
{
        uchar i;
        if(num==0)
        {
                for(i=9;i>0;i--)
                {
                         disp_buffer[i-1]=' ';
                                }
                disp_buffer[9]=0x30;
        }
        else
        {
                for(i=10;i>0;i--)
                {
                        if(num==0)
                        {
                                disp_buffer[i-1]=' ';
                        }
                        else
                        {
                                disp_buffer[i-1] = ((num % 10)+0x30);
                                num /= 10;
                        }
                }
        }
}
 楼主| kuyu20 发表于 2010-8-16 12:36 | 显示全部楼层
只要省代码就行
 楼主| kuyu20 发表于 2010-8-16 12:38 | 显示全部楼层
看到num % 10、num /= 10就猜到代码和速度都不省了。

继续求!
aihe 发表于 2010-8-16 13:05 | 显示全部楼层
自己知道还求啥
 楼主| kuyu20 发表于 2010-8-16 16:31 | 显示全部楼层
求最省代码空间的啊
new1988 发表于 2010-8-16 20:56 | 显示全部楼层
4# kuyu20
单字节的乘除法是不怎么占空间滴!在汇编里面有乘除法的指令啊,是多字节的乘除法就占空间
hotpower 发表于 2010-8-16 21:20 | 显示全部楼层
记得邓苗挑战过极限。
t.jm 发表于 2010-8-17 08:32 | 显示全部楼层
20分,求一个最节省代码空间的long int转BCD的程序
kuyu20 发表于 2010-8-16 12:06

用循环减法,再把4个循环减法(-10000,-1000,-100,-10)合并到一个函数,
这样应该会省点空间。
btzhy 发表于 2010-8-17 10:12 | 显示全部楼层
sprintf(buf, "%ld", l_value);
t.jm 发表于 2010-8-17 10:15 | 显示全部楼层
sprintf(buf, "%ld", l_value);
btzhy 发表于 2010-8-17 10:12

一个sprintf的代码就吓死认了。
new1988 发表于 2010-8-18 08:17 | 显示全部楼层
9# t.jm
你这个方法不省空间,但是效率高!
new1988 发表于 2010-8-18 08:18 | 显示全部楼层
https://bbs.21ic.com/icview-178272-1-1.html
去看看这个贴子,里面有省空间的,也有高效率的
 楼主| kuyu20 发表于 2010-9-2 18:53 | 显示全部楼层
不关心这个了,兑现承若给分。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

14

主题

65

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部