首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

求公式的结果,要求精度达小数点后一万位以上.该如何解决

2012-02-23 
求公式的结果,要求精度达小数点后一万位以上.这是同学推出的数学公式,让我求结果,请大家给给建议.[img]htt

求公式的结果,要求精度达小数点后一万位以上.
这是同学推出的数学公式,让我求结果,请大家给给建议.
[img]http://www1.freep.cn/Photo.php?url=photo5/0702201528342386.gif[\img]
要求n至少是10的10次方.
不太好弄,大家有什么解决的方法

[解决办法]
给你个解决精度问题的例子.这个是10000的阶乘的例子.别总整个图片,怕毒.
# include <stdio.h>
# include <stdlib.h>
// 计算
# define N 1000
int cal(unsigned int *s,int n)
{
unsigned long p; // p是对每一位乘法中的值加上进位,如34*5,4*5是20,3*5的加上进位2是17
unsigned long k=0; // k是一次乘法中的进位,如10进制乘法中,34*5,4*5的进位是2,3*5的进位是1
int i;
static int m=1; // m是位数,表示s有总共有多少位数字,注意:是1000进制
static int b=0;
/* b用来记录后面的0,比如213,000,000,000,则b=3,后面的3个000不必再参与计算了 */
//
for(i=b;i <m;i++)
{
p=(long)s[i]*(long)n+k;
k=p/N;
s[i]=p-k*N;
}
// b是低位乘出来的000的数目,增加后加1
while(!s[b])
b++;
// 最高位的进位处理
for(k=p/N;k;)
{
p=k;
k=p/N;
s[i++]=p-k*N;
m++; // 进一次m加一次
}
return m;
}
void main()
{
/* s是用来存计算结果的,以N为进位,这里N=1000,如s[0]=1,s[1]=21,s[2]=213,s[3]以上都为0,
则结果是:213,021,001
*/
unsigned int *s;
int i;
int m; // m是位数,表示s有总共有多少位数字,注意:是1000进制
int n; /* 求n! (0 <n <10000)*/
printf( "输入一个整数(0-10000): " );
scanf( "%d ",&n); // 输入n的值
s=(unsigned int *)malloc(n*sizeof(s)*10); // 数组开足够大,其实要不了这么大
// 附初值,S=1,即s[0]=1,以上都为0
for(i=1;i <n;i++)
s[i]=0;
s[0]=1;
// 循环,s乘以2、3、4,……,n
for(i=2;i <=n;i++)
m=cal(s,i);
// 输出:n!=
printf( "\n%d!= ",n);
m=n-1;
// 滤掉前面的0,前面说了,其实
while(!s[m])
m--;
// 输出第一位
printf( "%d ",s[m--]);
// 输出后面的位数
for(i=m;i> =0;i--)
printf( ",%03d ",s[i]);
printf( "\n ");
// 释放内存空间
free(s);
}
[解决办法]
还是找个大数运算的函数库比较省事,比如GMP(http://www.swox.com/gmp/)

热点排行