c - 阶乘函数只能数到 12

标签 c algorithm factorial integer-overflow

对于 13 及以上,该阶乘函数开始给出错误的结果。我不知道为什么。

#include <stdio.h>

int fatorial (int p);

int main() {
    int x = 13;
    int test = fatorial(x);
    printf("%d", test);
}  

int fatorial (int p) {
    if (p <= 0)
        return 1;
    else
        return p*fatorial(p-1);
}

对于 x = 0, 1, 2 ...12,它打印正确的结果,但是对于 13!它打印 1932053504 这是不正确的。 例如,对于 x=20,它会打印 -210213273。

我知道这不是进行阶乘的最佳方法。不过,这是我的作业,它必须是这样的。

最佳答案

如果您尝试此操作,您将获得最大值 int可容纳:

#include <stdio.h>
#include <limits.h>
int main(void) 
{
    printf("%d\n", INT_MAX);
}

您的代码导致溢出。

如果您使用更大的类型,您可能会得到更多的数字,但不会太多。你可以使用这个:

unsigned long long fatorial (unsigned long long p) {
    if (p <= 0)
        return 1;
    else
        return p*fatorial(p-1);
}

但这不会让你走得太远。如果您想要更大的整数,则需要找到更大整数的库或创建一些自定义解决方案。此类库之一是 https://gmplib.org/但这可能超出了你的作业范围。

顺便说一句,类似 p <= 0 的条件不好。它表示负数的阶乘始终为 1,这是错误的。

关于c - 阶乘函数只能数到 12,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63904071/

相关文章:

c++ - C/C++ 分配类似对象的数组数组

c - 我无法理解优先级反转是如何发生的

java - 显示输出的特定数字//从 bigInteger 中删除 0

php - 具有意外输出的其他循环

c++ - 具有大阶乘的数学(例如除法?)

c - 如何使排序功能更简单(或更短)

c - 在使用 C 时读取链接列表的文本文件

c - 在 C 中实现最小堆

algorithm - 触发道格拉斯-普克算法最坏情况的线?

ruby - 将哈希合并为稀疏矩阵的高效算法