<分区>
我正在编写一个程序,使用 main
() 函数的递归来计算阶乘。
/* Print factorial */
#include <stdio.h>
#include <stdlib.h>
static char **p;
int main(int argc, char **argv)
{
int n, rv;
if (argc < 2) {
printf("Usage: a.out <value>\n");
exit(-1);
}
n = atoi(argv[1]);
if (!n) {
rv = 0;
} else {
if (n == 1) {
rv = 1;
} else {
n = n - 1;
**p = n;
main(2, p);
}
}
printf("%d\n", rv);
return 0;
}
该程序使用 gcc
进行编译,但在执行时,我在 **p = n
处遇到了段错误。有人可以帮我修改上面的程序以获得正确的结果吗?此外,在 main
() 中的连续递归调用之间捕获正确的 rv
值的逻辑是什么?