
用C++如何求n!的阶层
任意输入一个数,得到它的阶层,应该怎么做?要完整的,可编译运行的最好可以用两种方式,一种递归,另一种不用递归...
任意输入一个数,得到它的阶层,应该怎么做?
要完整的,可编译运行的
最好可以用两种方式,一种递归,另一种不用递归 展开
要完整的,可编译运行的
最好可以用两种方式,一种递归,另一种不用递归 展开
6个回答
展开全部
不递归
#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);
}
#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);
}
展开全部
第一个递归:
#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;
}
}
#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;
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不用递归的
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));
}
}
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));
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#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;
}是不是这样写
int fun(int n)
{
if(n==0 || n==1) return 1;
else return n *fun(n-1);
}
void main()
{
cout<<fun(2)<<endl;
}是不是这样写
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#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();
}
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();
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询