为什么我的代码在 9 之后不生成阶乘?
Why is my code not generating factorial after 9?
用 C 编写一个程序来计算从命令行传递的数字的阶乘。这
阶乘必须在称为 computeFact( ) 的单独函数中计算,该函数具有以下内容
原型:
int computeFact(int,…);
#include <stdarg.h>
#include <stdio.h>
#include<stdlib.h>
int computeFact(int, ...);
int main(int argc, char *argv[])
{
if (argc < 2)
{
printf("Invalid!");
} else {
for (int i = 1; i < argc; i++)
{
int n = atoi(argv[i]);
printf("Factorial of %d is %d\n", n, computeFact(n));
}
}
printf("\n");./
return 0;
}
int computeFact(int num, ...)
{
va_list valist;
int fact = 1;
va_start(valist, num);
for (int i = 0; i < num; i++)
{
int x=va_arg(valist, int);
if(x==0)
return 1;
else
{
for(int j = 1; j <= x; j++)
fact=fact*j;
return fact;
}
}
va_end(valist);
}
输出结果如下:
~$ ./1 1 2 3 4 5 6 7 8 9 10
Factorial of 1 is 1
Factorial of 2 is 2
Factorial of 3 is 6
Factorial of 4 is 24
Factorial of 5 is 120
Factorial of 6 is 720
Factorial of 7 is 5040
Factorial of 8 is 40320
Factorial of 9 is 362880
Factorial of 10 is 1
~$ ./1 0
Factorial of 0 is 1
~$ ./1 99
Factorial of 99 is 362880
~$ ./1 98
Factorial of 98 is 40320
~$ ./1 5
Factorial of 5 is 120
我认为在将字符串转换为 int 时存在一些错误,因为计算阶乘时只占用了两位数中的最后一位,但我无法确定我的代码中究竟应该更正什么代码.
您正在通过 va_arg
.
读取不存在的参数来调用 未定义的行为
看来您应该停止使用 va_*
宏,在这种情况下只需使用参数 num
。
int computeFact(int num, ...)
{
int fact = 1;
int x=num;
if(x==0)
return 1;
else
{
for(int j = 1; j <= x; j++)
fact=fact*j;
return fact;
}
}
还要注意 int
的限制。 99!
将是十进制的 156 位数字,它不在典型 int
的范围内(最多 2,147,483,647 = 2**31 - 1
)。
试试下面的代码:
int computeFact(int num, ...)
{
int fact = 1;
int x = num;
if(x==0)
return 1;
else
{
for(int value = 1; value <= x; value++)
fact=fact*value;
return fact;
}
}
用 C 编写一个程序来计算从命令行传递的数字的阶乘。这 阶乘必须在称为 computeFact( ) 的单独函数中计算,该函数具有以下内容 原型: int computeFact(int,…);
#include <stdarg.h>
#include <stdio.h>
#include<stdlib.h>
int computeFact(int, ...);
int main(int argc, char *argv[])
{
if (argc < 2)
{
printf("Invalid!");
} else {
for (int i = 1; i < argc; i++)
{
int n = atoi(argv[i]);
printf("Factorial of %d is %d\n", n, computeFact(n));
}
}
printf("\n");./
return 0;
}
int computeFact(int num, ...)
{
va_list valist;
int fact = 1;
va_start(valist, num);
for (int i = 0; i < num; i++)
{
int x=va_arg(valist, int);
if(x==0)
return 1;
else
{
for(int j = 1; j <= x; j++)
fact=fact*j;
return fact;
}
}
va_end(valist);
}
输出结果如下:
~$ ./1 1 2 3 4 5 6 7 8 9 10
Factorial of 1 is 1
Factorial of 2 is 2
Factorial of 3 is 6
Factorial of 4 is 24
Factorial of 5 is 120
Factorial of 6 is 720
Factorial of 7 is 5040
Factorial of 8 is 40320
Factorial of 9 is 362880
Factorial of 10 is 1
~$ ./1 0
Factorial of 0 is 1
~$ ./1 99
Factorial of 99 is 362880
~$ ./1 98
Factorial of 98 is 40320
~$ ./1 5
Factorial of 5 is 120
我认为在将字符串转换为 int 时存在一些错误,因为计算阶乘时只占用了两位数中的最后一位,但我无法确定我的代码中究竟应该更正什么代码.
您正在通过 va_arg
.
看来您应该停止使用 va_*
宏,在这种情况下只需使用参数 num
。
int computeFact(int num, ...)
{
int fact = 1;
int x=num;
if(x==0)
return 1;
else
{
for(int j = 1; j <= x; j++)
fact=fact*j;
return fact;
}
}
还要注意 int
的限制。 99!
将是十进制的 156 位数字,它不在典型 int
的范围内(最多 2,147,483,647 = 2**31 - 1
)。
试试下面的代码:
int computeFact(int num, ...)
{
int fact = 1;
int x = num;
if(x==0)
return 1;
else
{
for(int value = 1; value <= x; value++)
fact=fact*value;
return fact;
}
}