【发布时间】:2020-09-15 14:29:54
【问题描述】:
这个阶乘函数从 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类型来说太大了。 -
尝试使用
unsigned long long int而不是int,你会得到更多正确的阶乘。 -
您的代码中发生int溢出,您可以尝试打印INT_MAX来检查整数的限制。您可以尝试使用 unsigned long long int 以获得对 int 的最高支持
标签: c algorithm factorial integer-overflow