代码如下所示:
#include<stdio.h>
main()
{
long fac(int n);//递归函数的声明
int n;
long y;//定于整形可能会出现溢出现象
printf("请输入要求阶乘的数:");
scanf_s("%d", &n);
y = fac(n);//调用递归函数
printf("%ld", y);
}
long fac(int n)
{
long f;
if (n== 1 || n == 0)//0或者1的阶乘都是1
f = 1;
else
f =n* fac(n-1);//等价于n*n-1*n-2.....
return f;
}
输出结果如下:
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/81533.html