目前的51单片机在进行带小数点结果的除法一般可以采用浮点数计算的方式,但是浮点数计算有一个缺点就是非常耗时,在对时间要求严格的工况就不太适用。 笔者的工作室长期承接单片机、电路、机电液、工控、自动化、计算机软件等项目,最近做了个单片机计算器的设计,在设计除法时利用长整形除法和取余运算,可以得到若干小数位的精度运算,与大家共享。 设计思路如下: 假设长整形除数a, 长整形被数b,步骤如下: <1>得到除法的整数部分,c=a/b; <2>设d为a%b,e=10*d, 得到除法的第一位小数,f=e/b; (要点:将a余b的余数乘以10倍,再和被除数b相除,就得到小数点后一位小数) <3>设g为e%b,h=10*g, 得到除法的第二位小数,i=h/b; 以此类推,可以得到除法的任意小数…… /**********************************下面附上C语言程序 **********************************************************/ unsigned long result, result_p;//表示除法结果的整数和小数部分 // result_p是小数部分,例如result_p=12345678,表示0.12345678 Void chufa(unsigned long chushu, unsigned long beichushu, unsigned char wei) // wei表示精确到小数点后多少位 { unsigned char i; unsigned long tmp; result=result_p=0; if (beichushu!=0)//被除数必须不为0 { if (wei==0) {result=chushu/beichushu;//计算整数部分 result_p=0; } else {result=chushu/beichushu;//计算整数部分 tmp=chushu%beichushu; for (i=1;i<=wei;i++)//计算小数部分 {tmp=tmp*10; result_p=result_p*10+tmp/beichushu; tmp=tmp%beichushu; } } }
|