根据e=1/1!+1/2!+,+1/n!用C++设计一个编程来计算e精确到1000位能不能给个简单的编程.楼下那个也许是对的,可在我的C++运行环境GUIDE里运行不出来,显示多处错误.
来源:学生作业帮助网 编辑:作业帮 时间:2024/12/04 06:54:37
根据e=1/1!+1/2!+,+1/n!用C++设计一个编程来计算e精确到1000位能不能给个简单的编程.楼下那个也许是对的,可在我的C++运行环境GUIDE里运行不出来,显示多处错误.
根据e=1/1!+1/2!+,+1/n!用C++设计一个编程来计算e精确到1000位
能不能给个简单的编程.楼下那个也许是对的,可在我的C++运行环境GUIDE里运行不出来,显示多处错误.
根据e=1/1!+1/2!+,+1/n!用C++设计一个编程来计算e精确到1000位能不能给个简单的编程.楼下那个也许是对的,可在我的C++运行环境GUIDE里运行不出来,显示多处错误.
这个问题首先是数据存储形式和运算问题.现有的 数据类型没有一种能满足要求,必须定义自己的类型.
可以定义定点的或浮点十进制,定长或不定长存储,
定长存储计算比较简便,不定长计算较为复杂,
算式求和与阶乘的算法并不复杂,可以用递归实现
定义数据类
class VeryLongNumber {
//数据成员
//方法和操作符 set + - * / += -= *= /= ++ --
//包括与标准数据类型的运算符
}
void fun(class VeryLongNumber * t,int n)
{
if(n==1){
t->set(1);
return;
}
fun(t,n-1);
class VeryLongNumber tmp(1);
tmp/=n;
(*t) *= tmp;
}
void sum (class VeryLongNumber * sumo,int n){
if(n==1){
sumo->set(1);
return;
}
sum(sumo,n-1);
class VeryLongNumber * tmp=new VeryLongNumber(0);
fun(tmp,n);
(*sumo)+=(*tmp);
delete tmp;
}
要完善自定义的极长精度的数据类型绝非一时半刻能办的到的还要不断摸索,测试,反复修改.有了方法和思路,离实现就进了一步.这是现编的程序也没有测试难免有错误,思路没有问题.以后有时间再考虑自定义极长精度数据类型问题
搂主,数据类必须把内部的成员函数全部声明后,下边的程序才能编译通过,现在运行是不可以的,必须完善数据类以后才能运行
如果先用double 型代替 可以测试下面的函数是否算法正确.
方法 用double 代换 class VeryLongNumber
set 函数 和对象置初值 直接用赋值
然后就可以运行了,不过精度不够,n不能过大
极长精度数据类 可以用类似double 方法
class VeryLongNumber {
int power;
int data[1500];
VeryLongNumber (){ power=0;for(int i=0;i