在此示例中,您将学习计算用户输入的数字的阶乘。
要理解此示例,您应该了解以下C语言编程主题:
正数n的阶乘为:
factorial of n (n!) = 1 * 2 * 3 * 4....n
负数的阶乘不存在。0的阶乘是1。
#include <stdio.h>
int main() {
int n, i;
unsigned long long fact = 1;
printf("输入一个整数: ");
scanf("%d", &n);
//如果用户输入负整数,则显示错误
if (n < 0)
printf("错误! 不存在负数阶乘。");
else {
for (i = 1; i <= n; ++i) {
fact *= i;
}
printf("%d 的阶乘 = %llu", n, fact);
}
return 0;
}输出结果
输入一个整数: 10 10 的阶乘 = 3628800
该程序从用户处获取一个正整数,并使用for循环计算阶乘。
由于数字的阶乘可能很大,因此阶乘变量的类型声明为unsigned long long。
如果用户输入一个负数,程序将显示一个自定义错误消息。
您还可以使用递归找到数字的阶乘。