杭电 ACM1465 答案明明是对的啊 为什么老是说我WA啊 希望各位帮忙看看啊

#include<iostream>usingnamespacestd;intf(intn);intmain(){intn;while(cin>>n)if(n<=1||n... #include<iostream>
using namespace std;
int f(int n);
int main()
{
int n;
while(cin>>n)
if(n<=1||n>20)
break;
else
cout<<f(n)<<endl;
return 1;
}
int f(int n)
{
int x;
if(n==2)
x=1;
else if(n==3)
x=2;
else
x=(n-1)*(f(n-1)+f(n-2));
return x;
}
展开
 我来答
xyh8805012
2010-11-13 · TA获得超过110个赞
知道小有建树答主
回答量:70
采纳率:0%
帮助的人:79.6万
展开全部
答案超出int,物键应用long long 下面是我帮你改的:
#include<iostream>
using namespace std;
long long f(long long n);
int main()
{
int n;
while(cin>>n)
if(n<=1||n>历渣20)
break;
else
cout<<f(n)<<endl;
return 1;
}
long long f(long long n)
{
long long x;
if(n==2)
x=1;
else if(n==3)
x=2;
else
x=(n-1)*(f(n-1)+f(n-2));
return x;
}
这个就可以肢蚂悄AC的
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式