📜  C查找数字阶乘的程序

📅  最后修改于: 2020-10-04 11:25:03             🧑  作者: Mango

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

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

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

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


数字的阶乘
#include 
int main() {
    int n, i;
    unsigned long long fact = 1;
    printf("Enter an integer: ");
    scanf("%d", &n);

    // shows error if the user enters a negative integer
    if (n < 0)
        printf("Error! Factorial of a negative number doesn't exist.");
    else {
        for (i = 1; i <= n; ++i) {
            fact *= i;
        }
        printf("Factorial of %d = %llu", n, fact);
    }

    return 0;
}

输出

Enter an integer: 10
Factorial of 10 = 3628800

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

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

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

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