c++里判断一个浮点数大于0怎么判?

beiguoyouzi 2013-04-26 11:07:08
林锐的《高质量C/C++编程》里有浮点数不等于0的判断,先加入判断一个浮点数在0到某个数的区间时,比如说(0,130),怎么判?
第一种方法
float a;
...
if(a>0.0 && a<130.0)
{...}
第二种方法
float a;
...
if(a>0.00001 && a<130.0)
{...}
第三种方法
float a;
...
if(a>1.0E-15 && a<130.0)
{...}
这上面哪种方法正确,谢谢大拿。
...全文
2360 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
hugett 2013-04-27
  • 打赏
  • 举报
回复
第一种是不行的,第二种比较好,一般取到10^-5到10^-8就可以了。。
c1997sdn 2013-04-27
  • 打赏
  • 举报
回复
第一种用起来没问题啊。
ztenv 版主 2013-04-27
  • 打赏
  • 举报
回复
c语言里讲过的哟,和你需要的精度有关系,
nice_cxf 2013-04-27
  • 打赏
  • 举报
回复
都不对,如果没经过计算直接1就可以 如果经过计算那么 两边都要做处理应该是类似 if(a>0.00001 && a<130.001f) 具体是多少要看你自己的需求精度,不是一个固定的数值
赵4老师 2013-04-27
  • 打赏
  • 举报
回复
因为 float.h
...
#define FLT_DIG         6                       /* # of decimal digits of precision */
#define FLT_EPSILON     1.192092896e-07F        /* smallest such that 1.0+FLT_EPSILON != 1.0 */
#define FLT_GUARD       0
#define FLT_MANT_DIG    24                      /* # of bits in mantissa */
#define FLT_MAX         3.402823466e+38F        /* max value */
#define FLT_MAX_10_EXP  38                      /* max decimal exponent */
#define FLT_MAX_EXP     128                     /* max binary exponent */
#define FLT_MIN         1.175494351e-38F        /* min positive value */
#define FLT_MIN_10_EXP  (-37)                   /* min decimal exponent */
#define FLT_MIN_EXP     (-125)                  /* min binary exponent */
#define FLT_NORMALIZE   0
#define FLT_RADIX       2                       /* exponent radix */
#define FLT_ROUNDS      1                       /* addition rounding: near */
...
所以
#include <float.h>
float f;
if (f>FLT_EPSILON)//f大于0.0f
千树之影 2013-04-27
  • 打赏
  • 举报
回复
看你是不是真的想和‘0’比较了。 例如你想要判断数的正负,那就是应该用第一种。
漫步者、 2013-04-26
  • 打赏
  • 举报
回复
浮点数,后面都是保留6位小数来着,第二种吧
疯狂的红豆 2013-04-26
  • 打赏
  • 举报
回复
浮点数在和一个区间作比较的时候还是和整数一致的,因为要比较的是一个大小关系,虽然浮点数在内存中的存储是一个近似值,但是这不影响它与一个确定的数值的比较结果。 关于浮点数与其零值的比较倒是和整数值不一样了,整数值在内存中的存储是精确的,所以是不是整数零值很确定。但是 浮点数因为是近似值存储(因为所有的值都是以2的幂的形式的和),一般认为在某一个很小的范围内时就认为是浮点数的零值了,至于这个区间的设定,一般是10的负5方吧。
Python编程基础教程本教程旨在帮助初学者了解Python编程的基础知识和高级应用。我们将介绍Python的各个方面,包括基础语法、数据类型、控制结构、函数、文件操作、面向对象编程、模块和包、异常处理、装饰器、生成器、迭代器以及协程。1. Python基础Python是一种解释型、交互式的编程语言。它具有简单易学的语法和丰富的库,使得开发过程既快速又高效。在开始学习Python之前,建议您先熟悉基本的计算机科学概念,例如变量、数据类型、运算符等。2. 数据类型Python具有多种数据类型,包括数字(整数和浮点数)、字符串、布尔值、列表、元组、集合和字典等。这些数据类型在Python中有着广泛的应用,从简单的数值计算到复杂的数据处理。3. 控制结构控制结构是编程中的基本组成部分,它们决定了程序如何执行。Python支持条件语句(if-elif-else)和循环语句(for和while),可以根据程序中的特定条件和情况来选择适当的操作。4. 函数函数是封装一段代码的便捷方式,它们可以在需要时被调用。在Python中,您可以定义函数,并使用参数来传递数据。函数可以返回值,以便在调用它们时使用。5. 文件操作文件操作是编程中常见的任务之一。Python提供了许多内置的函数和方法来进行文件操作,如读取、写入和删除文件等。此外,Python还支持对文件进行高级操作,如读写二进制文件、文件锁定等。6. 面向对象编程面向对象编程是一种流行的编程范式,它使用类和对象的概念来构建复杂的系统。Python支持面向对象编程,您可以使用类来定义对象,并使用继承和多态等特性来扩展和定制对象的行为。7. 模块和包模块和包是Python中组织代码的重要工具。模块是一个包含Python代码的文件,而包则是一个包含多个模块的目录。通过使用模块和包,您可以轻松地组织和管理大型项目中的代码。8. 异常处理异常处理是Python中处理错误的方式之一。当程序中出现错误时,Python会抛出一个异常。通过使用try-except语句块,您可以捕获并处理这些异常,以确保程序的稳定性。9. 装饰器装饰器是Python中的高级功能之一,它允许您在函数或方法之间添加额外的功能,而不改变其原始实现。装饰器是一种强大的工具,可用于实现各种功能,如日志记录、性能分析等。10. 生成器生成器是Python中的一种特殊类型的迭代器。通过使用生成器函数和方法,您可以在需要时生成数据,而不是一次性生成所有数据。这使得生成器在处理大量数据时非常有用,因为它们可以节省内存空间。11. 迭代器和协程迭代器和协程是Python中的两个重要概念。迭代器允许您遍历容器类型的数据结构(如列表和元组),而协程则是一种异步编程的方式,它允许您在程序中执行多个任务并发执行。这两个概念在处理大量数据和高性能应用程序方面非常有用。

64,652

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧