用C++如何求n!的阶层

任意输入一个数,得到它的阶层,应该怎么做?要完整的,可编译运行的最好可以用两种方式,一种递归,另一种不用递归... 任意输入一个数,得到它的阶层,应该怎么做?
要完整的,可编译运行的
最好可以用两种方式,一种递归,另一种不用递归
展开
 我来答
御风__弄影
推荐于2017-09-12 · TA获得超过659个赞
知道小有建树答主
回答量:250
采纳率:0%
帮助的人:272万
展开全部
不递归
#include <iostream>
using namespace std;
int main()
{
int i,n,rel;
cout<<"输入n:"<<endl;
cin>>n;
for(i=1;i<n+1;i++)
rel *= i;
cout<<rel<<endl;
return 0;
}

递归:
#include <iostream>
using namespace std;
int fac(int);
int main()
{
int n,rel;
cout<<"输入n:"<<endl;
cin>>n;
rel = fac(n);
cout<<rel<<endl;
return 0;
}
int fac(int i)
{
if(i == 0)
return 1;
else
return i * fac(i-1);
}
nationwater
2009-03-26 · TA获得超过260个赞
知道小有建树答主
回答量:143
采纳率:0%
帮助的人:161万
展开全部
第一个递归:
#include <stdio.h>

int f(int x)
{
if (x == 1)
{
return 1;
}
else if ( x != 1)
{
return f(x - 1) * x;
}
}

int main()
{
int n;
int res;
printf("请输入一个数\n");
scanf("%d", &n);
if ( n<=0 )
{
printf("输入错误\n");
return 0;
}
else
{
res = f(n);
printf("结果为%d\n", res);
return 1;
}
}

第二个不递归
#include <stdio.h>

int main()
{
int n;
int res;
int i;
res = 1;
printf("请输入一个数\n");
scanf("%d", &n);
if ( n<=0 )
{
printf("输入错误\n");
return 0;
}
else
{
for (i = 0; i < n; i++)
{
res = (i + 1) * res;
}
printf("结果%d", res);
return 1;
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
TreagZhao
2009-03-26 · TA获得超过1397个赞
知道小有建树答主
回答量:856
采纳率:0%
帮助的人:647万
展开全部
不用递归的
int fun(int n)
{ int r=1;
for(int i=2;i<=n;i++)
r*=i;
return r;
}

int main()
{ int n;
while(scanf("%d",&n)!=0)
{ printf("%d\n",fun(n));
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wanfustudio
2009-03-26 · TA获得超过1万个赞
知道大有可为答主
回答量:5513
采纳率:100%
帮助的人:4157万
展开全部
#include<iostream.h>

int fun(int n)
{
if(n==0 || n==1) return 1;
else return n *fun(n-1);
}

void main()
{
cout<<fun(2)<<endl;
}是不是这样写
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
8895我
2013-03-11
知道答主
回答量:2
采纳率:0%
帮助的人:3028
展开全部
#include<iostream.h>
class factorial
{
private:
int n;
int m;
public:
factorial(int a){n=a;m=n;}
int mult();
void print()
{
cout<<"sum="<<mult()<<endl;
}
};
int factorial::mult()
{
for(long sum=0;n>0;n--)
{ for(int i=1,s=1;i<=n;i++)
s=s*i;
sum=sum+s;
}
return sum;
}
int main()
{
int a;
cin>>a;
factorial A(a);
A.print();
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式