标题:有趣的阶乘
取消只看楼主
神雕大侠
Rank: 1
等 级:新手上路
帖 子:28
专家分:0
注 册:2007-5-18
 问题点数:0 回复次数:1 
有趣的阶乘

阶乘有多大?

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的阶乘以内可以正常运行,大于它之后数据就会溢出,但是定义的数据的长度已经是最大的了。请问一下怎么处理这个问题?

搜索更多相关主题的帖子: 阶乘 
2007-10-13 09:29
神雕大侠
Rank: 1
等 级:新手上路
帖 子:28
专家分:0
注 册:2007-5-18
得分:0 
回复:(coachard)晕,当然啦,溢出了嘛。。。如果你...
用高精度怎么算呀?能不能给个代码?
2007-10-13 22:27



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-177217-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.179739 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved