原文: https://www.programiz.com/c-programming/examples/factorial

在此示例中,您将学习计算用户输入的数字的阶乘。

要理解此示例,您应该了解以下 C 编程主题:


正数n的阶乘由下式给出:

  1. factorial of n (n!) = 1 * 2 * 3 * 4....n

负数的阶乘不存在。 并且,阶乘 0 为 1。


数字的阶乘

  1. #include <stdio.h>
  2. int main() {
  3. int n, i;
  4. unsigned long long fact = 1;
  5. printf("Enter an integer: ");
  6. scanf("%d", &n);
  7. // shows error if the user enters a negative integer
  8. if (n < 0)
  9. printf("Error! Factorial of a negative number doesn't exist.");
  10. else {
  11. for (i = 1; i <= n; ++i) {
  12. fact *= i;
  13. }
  14. printf("Factorial of %d = %llu", n, fact);
  15. }
  16. return 0;
  17. }

输出

  1. Enter an integer: 10
  2. Factorial of 10 = 3628800

该程序从用户处获取一个正整数,并使用for循环计算阶乘。

由于数字的阶乘可能很大,因此阶乘变量的类型声明为unsigned long long

如果用户输入一个负数,程序将显示一个自定义错误消息。

您还可以使用递归查找数字的阶乘