C++ 求n的阶乘,我这个程序有什么错误啊
#include<iostream>usingnamespacestd;intf(intn){intc;if(n<0){cout<<"错误"<<endl;}elseif(...
#include <iostream>
using namespace std;
int f(int n)
{
int c;
if (n<0)
{cout<<"错误"<<endl;}
else if (n=0,n=1)
f(n)=1;
else if (n>1) f(n)=n*f(n-1);
c=f(n);
return c;
}
void main()
{
int x,y;
cout<<"请输入n值:";
cin>>x>>endl;
y=f(x);
cout<<"n! = "<<y<<endl;
} 展开
using namespace std;
int f(int n)
{
int c;
if (n<0)
{cout<<"错误"<<endl;}
else if (n=0,n=1)
f(n)=1;
else if (n>1) f(n)=n*f(n-1);
c=f(n);
return c;
}
void main()
{
int x,y;
cout<<"请输入n值:";
cin>>x>>endl;
y=f(x);
cout<<"n! = "<<y<<endl;
} 展开
4个回答
展开全部
代码问题比较多,改好之后如下:
#include <iostream>
using namespace std;
int f(int n)
{
if (n<0)
{
cout<<"输入参数错误"<<endl;
return 0;
}
//n=0,1返回1
if (n==0||n==1)//=是赋值,==才是比较,两个之间或用||
return 1;//返回1是因为0和1的阶乘是1,也就是f(0)=1,f(1)=1,你这个函数返回的结果是n的阶乘
//如果n>1
return n*f(n-1);//这是因为n>1,那么你递归调用函数,直到获得结果
}
int main()
{
int n;
cout<<"请输入n值:";
cin>>n;//endl是输出的时候的换行,输入不能用
cout<<"n! = "<<f(n)<<endl;
return 0;
}
如果觉得不错,麻烦采纳,谢谢
追问
我改了改
if (n1)
f(n)= n*f(n-1);
return f(n); //最后返回一个f(n)
}
追答
哈哈,f(n)是一个函数,是不可以被赋值的,只有变量可以赋值,函数可以返回一个值,或者没有返回值;简单来说就是这样
展开全部
else if (n=0,n=1)...你的老师没告诉你,if里面判断是用==的么- -.
这个if(n = 0, n = 1)基本上是永远正确的,不过也要看机器环境.赋值语句的话是看右边那个表达式的值,n = 1.bool值就是true,话说赋值有真假么..还没学到过
int s(int val)
{
if(val > 1)
return s(val - 1) * val;
return 1;
}
别搞那么复杂.普通的递归就几句话.
这个if(n = 0, n = 1)基本上是永远正确的,不过也要看机器环境.赋值语句的话是看右边那个表达式的值,n = 1.bool值就是true,话说赋值有真假么..还没学到过
int s(int val)
{
if(val > 1)
return s(val - 1) * val;
return 1;
}
别搞那么复杂.普通的递归就几句话.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int f(int n){
if(n<1) return 1;
else return n*f(n-1);
}
if(n<1) return 1;
else return n*f(n-1);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
呵呵,你这个编译都通不过吧f(n)=1;改成return 1,其他类似
追问
编译确实有错,不过为什么要改成return1呢?直接把这个值给函数不行吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询