假设长整形除数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; } } }
|