【010】递归函数

//用递归方法求n!。

#include <iostream>

using namespace std;

long fac(int); //函数声明

int main( )

 {int n; //n为需要求阶乘的整数

long y; //y为存放n!的变量

cout<<″please input an integer :″; //输入的提示                  

cin>>n; //输入n

  y=fac(n); //调用fac函数以求n!

  cout<<n<<″!=″<<y<<endl; //输出n!的值

  return 0;

 }

 

long fac(int n) //递归函数

{long f;

 if(n<0)

  {cout<<″n<0,data error!″<<endl; //如果输入负数,报错并以-1作为返回值

   f=-1;}

 else if (n==0||n==1) f=1; //0!和1!的值为1

else f=fac(n-1)*n; //n>1时,进行递归调用

 return f; //将f的值作为函数值返回

}

posted @ 2015-10-15 14:12  薛定谔的猪  阅读(157)  评论(0编辑  收藏  举报