当没有浮点数据类型时,为什么此代码会得到浮点异常?

时间:2018-07-11 22:14:05

标签: c++ c++14 floating-point-exceptions

我没有被零除,我的代码中没有浮点数据类型,我仍然遇到浮点异常。

#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;


int main() {
    unsigned long long int t,n;

    cin>>t;
    while(t--)
    {
        cin>>n;
        unsigned long long int deno = pow(10,n-1),count=2,sum = 0,f1=1,f2=1;

         while(1){
            sum = f1+f2;
            f1 = f2;
            f2 = sum;
            count++;
            if((int)(sum/deno)>0){
                cout<<count<<endl;
                 break;
             } 
        }

    }
    return 0;
}

同一问题上的所有先前问题都具有类似的除以零的问题,但变量deno不能像n>=2一样为零。

我以前的研究

  1. “Floating point exception” in code that contains no floats
  2. Floating Point Exception C++ Why and what is it?

问题陈述:https://www.hackerrank.com/contests/projecteuler/challenges/euler025/problem

它通过了2个测试用例,但失败了2个。所有都是隐藏的测试用例。 Result image

传递输入1 50时,我们可以重现错误。详细信息:

 GDB trace: Reading symbols from solution...done. [New LWP 15127] Core
 was generated by `solution'. Program terminated with signal SIGFPE,
 Arithmetic exception.
 #0  main () at solution.cc:23 
 23 if((int)(sum/deno)>0){
 #0  main () at solution.cc:23

1 个答案:

答案 0 :(得分:9)

在某些平台上(例如,Linux),整数除法产生一个被报告为“浮点异常”的异常是完全正常的。您可以轻松地将其从整数除以零,或者例如通过触发溢出,如

int i = INT_MIN;
int b = -1;
i = i / b;

http://coliru.stacked-crooked.com/a/07c5fdf47278b696

在某些情况下,根据优化级别的不同,此异常可能会出现或消失。通常只有在编译器决定生成实际的除法指令时才会触发该异常(与优化除法相反)。


在您的情况下,使用无符号整数除法,因此除以零似乎是唯一的罪魁祸首。我想这是

unsigned long long int deno = pow(10,n-1);

可能会在deno中导致零。 pow是产生浮点结果的浮点函数。如果原始值太大(从n等于50的情况来看),则从浮点类型到整数类型的转换将导致未定义的行为。请注意,即使目标整数类型是无符号的,也是这种情况。