| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1120 人关注过本帖
标题:有趣的阶乘
取消只看楼主 加入收藏
神雕大侠
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
快速回复:有趣的阶乘
数据加载中...
 
   



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

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