阶乘是一个数学概念,表示从1乘以2乘以3一直乘到给定的正整数n,在C语言中,我们可以使用循环或递归来实现阶乘的计算,下面是两种方法的详细解释和代码示例。
(图片来源网络,侵删)方法一:使用循环
思路:
1、定义一个变量用于存储结果,初始值为1。
2、使用for循环,从1遍历到n。
3、在循环中,将当前循环变量乘以结果变量,并将结果赋值给结果变量。
4、循环结束后,结果变量即为n的阶乘。
代码:
#include <stdio.h> int main() { int n, i; long long factorial = 1; printf("请输入一个正整数: "); scanf("%d", &n); for (i = 1; i <= n; i++) { factorial *= i; } printf("%d的阶乘为: %lld ", n, factorial); return 0; }
方法二:使用递归
思路:
1、定义一个函数,接收一个整数n作为参数。
2、如果n为1,返回1。
3、否则,返回n乘以调用该函数时传入n1的结果。
4、在主函数中,调用该递归函数并输出结果。
代码:
#include <stdio.h> long long factorial(int n) { if (n == 1) { return 1; } else { return n * factorial(n 1); } } int main() { int n; printf("请输入一个正整数: "); scanf("%d", &n); printf("%d的阶乘为: %lld ", n, factorial(n)); return 0; }
以上两种方法都可以实现阶乘的计算,你可以根据需要选择其中一种方法进行编程。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。