关于编程中遇到inf的情况
2016-02-29 19:36
302 查看
在进行编程的过程中我们常常会由于没有对分母是否为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");
后续大家根据自身的需要自己选择使用情况!
一、利用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");
后续大家根据自身的需要自己选择使用情况!
相关文章推荐
- <<第一行代码>>--全局获取Context技巧
- 算法代码实现之快速排序,Java实现
- PHP连接MySQL数据库过程
- Java如何对Map进行排序详解
- C/C++ union用法
- 隐马尔科夫模型的解码算法和前向算法
- Java服务器热部署的实现原理——java类的加载方式
- java发送邮件
- MATLAB对文件进行批量重命名
- 【转】远程结对编程实战:看看别人是怎么做的
- 【PHP项目部署二】Mysql环境配置
- 算法代码实现之快速排序,Golang(Go语言)实现
- Java学习笔记(四):流程控制
- PHP预定义接口之 ArrayAccess
- cloudsim安装,配置(到eclipse)
- Rc4 代码
- 将Java程序打jar包并运行
- 面向对象编程的一些理解
- 【PHP项目部署一】PHP环境配置
- 深入c++ new