注册 登录
编程论坛 C++教室

有趣的阶乘

神雕大侠 发布于 2007-10-13 09:29, 1120 次点击

阶乘有多大?

Time Limit:1000MS Memory Limit:65536K
Total Submit:1043 Accepted:296

Description

笨笨已经会编程计算机10以内的阶乘了,现在有人请他帮忙计算一下S=1!+2!+3!+…+n!(n≤50)其中“!”表示阶乘。他用原来的办法算来算去总是得不到正确结果。你能帮帮他,让他的程序AC吗?

Input

输入正整数N。

Output

输出结果S。

Sample Input


6

Sample Output


873

下面是我的程序
#include <iostream>
using namespace std;
unsigned long long int a (unsigned long long int n)
{
unsigned long int result;
if(n==0)
result=1;
else
result=n*a(n-1);
return result;
}
int main ()
{
unsigned long long int i,n,s;
cin>>n;
s=0;
for(i=1;i<=n;i++)
{
s=s+a(i);
}
cout<<s<<endl;
system ("PAUSE");
return 0;
}

这个程序在30的阶乘以内可以正常运行,大于它之后数据就会溢出,但是定义的数据的长度已经是最大的了。请问一下怎么处理这个问题?

7 回复
#2
coachard2007-10-13 09:46
晕,当然啦,溢出了嘛。。。

如果你想再撑一会儿,就用unsigned long long。如果你想彻底解决问题,就用高精度。
#3
china25qd2007-10-13 09:56
以下是引用coachard在2007-10-13 9:46:10的发言:
晕,当然啦,溢出了嘛。。。

如果你想再撑一会儿,就用unsigned long long。如果你想彻底解决问题,就用高精度。

不是usingned long long好不好,是double long呢!

#4
coachard2007-10-13 09:58
回复:(china25qd)以下是引用coachard在2007-10-13 ...
你了解C99的数据类型不?
对于你的怀疑你验证过没?

如果都没有,请先别发表言论!!!

[此贴子已经被作者于2007-10-13 10:01:37编辑过]

#5
魔城侠客2007-10-13 10:11

可以将所得结果放在数组中,如123456,放在数组中a[0]=1,a[1]=2,.....
n!=n*(n-1)!,可以看成n个(n-1)!相加,这个就可以算任何大的数了,只要内存够

#6
神雕大侠2007-10-13 22:27
回复:(coachard)晕,当然啦,溢出了嘛。。。如果你...
用高精度怎么算呀?能不能给个代码?
#7
coachard2007-10-13 22:28

记得C版的版主卧龙孔明和前版主雨中飞燕都有现成的代码,,,你去C版搜搜。。。

#8
nuciewth2007-10-14 13:39
嘿嘿,50!内的C的数据,类型是包含不了的.
我写过100!,但很垃圾的东西.
还是去看版主卧龙孔明和前版主雨中飞燕的.
可以计算10000!.
1