芯源半导体CW32
直播中

万航渡路

9年用户 1409经验值
擅长:电源/新能源
私信 关注
[经验]

C语言快速精度除法的方案

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

}

}

}

更多回帖

发帖
×
20
完善资料,
赚取积分