tek*_*agi 1 c signals sigfpe pascals-triangle
由于某种原因,它曾经工作过.但现在我得到了一个SIGFPE .....出了什么问题?
#include "usefunc.h"
long factorial(long num) {
if (num > 1) {
long counter;
long fact = 1;
for (counter = num; counter > 0; counter--) fact *= counter;
return fact;
}
else return 0;
}
long combinations(long n, long k) {
return (factorial(n)) / (factorial(k)*factorial(n-k));
}
int main()
{
printf("How many rows of Pascal\'s triangle should I print?\t");
int rows = GetInteger();
long pArray[rows][rows];
int counter;
int counter2;
for (counter = 1; counter <= rows; counter++)
{
int y = rows-counter;
for (; y > 0; y--) printf(" ");
for (counter2 = 0; counter2 <= counter; counter2++)
{
/*
THIS IS AN OUTPUT
*/
printf("%9.0lu", (long) combinations(counter, counter2));
pArray[counter][counter2] = (long) combinations(counter, counter2);
}
/*
THIS IS AN OUTPUT
*/
printf("\n");
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
你的阶乘返回0,然后可能导致0分频错误.不应该返回1吗?
jcomeau@intrepid:/tmp$ cat test.c; make test;./test
#include <stdio.h>
int main() {
return printf("%f\n", 1L / 0);
}
cc test.c -o test
test.c: In function ‘main’:
test.c:3: warning: division by zero
Floating point exception
Run Code Online (Sandbox Code Playgroud)
我认为这是你的combinations函数,你没有向我们展示,因为你给出的代码都没有使用任何浮点数。
SIGFPE并不意味着浮点异常,即使那是名称的来源。@jcomeau 已正确确定您获得 SIGFPE 的原因。
| 归档时间: |
|
| 查看次数: |
5512 次 |
| 最近记录: |