关于编程中遇到inf的情况

  • Post author:
  • Post category:其他



在进行编程的过程中我们常常会由于没有对分母是否为0进行判断,从而造成结果值为inf或-inf,对这个问题,从根本上杜绝的话就是在做除法的时候对分母进行是否为0的判断,若后续需要对一个数是否为inf或-inf作判断的话,我们可以采用如下方法来做


一、利用C++中的numeric_limits来实现


在C++的头文件#include <limits> 中,有各个类型的最值。


如int 对应的最大最小值:std::numeric_limits<int>::min()  std::numeric_limits<int>::max()


如float对应的最大最小值:

std::numeric_limits<float>::min()


std::numeric_limits<

float

>::max()



那么对于一个数value,我们可以做如下判断:


若value为int:

if( (value < std::numeric_limits<int>::min()) || ( value > std::numeric_limits<int>::max() ) )
		printf("the value is inf or -inf\n");


若value为float:


if( (value < std::numeric_limits<float>::min()) || ( value > std::numeric_limits<float>::max() ) )
		printf("the value is inf or -inf\n");


其它的情况类似


二、利用inf自身的特性


我们发现对于为inf的数值,其对自身的任意操作仍为自身所以我们可以有很简单的判断条件


if ( value + 1 == value - 1)
		printf("the value is inf or -inf\n");


后续大家根据自身的需要自己选择使用情况!





版权声明:本文为xiaxiazls原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。