- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我试图让用户输入一个介于 1.00000 到 0.00001 之间的数字,同时边缘不包含在浮点变量中。我可以假设用户在点后输入的数字不超过 5 个。现在,这是我写的:
printf("Enter required Leibniz gap.(Between 0.00001 to 1.00000)\n");
scanf("%f", &gap);
while ((gap < 0.00002) || (gap > 0.99999))
{
printf("Enter required Leibniz gap.(Between 0.00001 to 1.00000)\n");
scanf("%f", &gap);
}
现在,当我键入可能的最小数字时:0.00002 陷入了 while 循环。当我运行调试器时,我看到 0.00002 与此值一起存储在浮点变量中:1.99999995e-005任何人都可以为我澄清我做错了什么?为什么 0.00002 不满足条件?这个“1.99999995e-005”是什么东西。
最佳答案
这里的问题是您使用的是 float
变量 ( gap
),但您将其与 double
进行比较常数(0.00002
)。常量是double
因为除非另有说明,否则 C 中的浮点常量是 double 的。
一个潜在的问题是数字 0.00002
在 float
中均不可表示或 double
. (它根本不能用二进制 float 表示,因为它的二进制展开式是无限长的,就像 ⅓ 的十进制展开式一样。)所以当你写 0.00002
时在程序中,C 编译器将其替换为 double
非常接近 0.00002
的值.同样,当scanf
读取编号 0.00002
进入float
变量,它代替一个 float
非常接近 0.00002
的值.自 double
数字的位数多于 floats
, double
值更接近 0.00002
比float
值(value)。
当您比较两个精度不同的浮点值时,编译器会将精度较低的值转换为精度较高的完全相同的值。 (表示为 double
的值集是表示为 float
的值集的超集,因此总是可以找到一个 double
其值与 float
的值相同。)这就是 gap < 0.00002
时发生的情况。被执行:gap
转换为 double
相同的值,并与双倍(接近)0.00002
进行比较.由于这两个值实际上都略小于 0.00002,并且 double
更近了,float
小于 double
.
您可以通过多种方式解决此问题。首先,您可以通过 gap
来避免转换。一个double
并更改 scanf
格式为 %lf
, 或者通过比较 gap
到 float
:
while (gap < 0.00002F || gap > 0.99999F) {
但出于几个原因,这并不完全正确。首先,实际上不能保证 C 编译器完成的浮点转换与标准库 (scanf
) 完成的转换相同,标准允许编译器使用“最接近的可表示值,或者以实现定义的方式选择的与最接近的可表示值紧邻的更大或更小的可表示值。” (它没有详细说明 scanf
产生哪个值,但建议它是最接近的可表示值。)碰巧的是,gcc
和 glibc
(Linux 上使用的 C 编译器和标准库)都产生最接近的可表示值,但其他实现不会。
无论如何,根据您的错误消息,您希望值介于 0.00001
之间和 1.00000
.所以你的测试应该是:
while (gap <= 0.00001F || gap >= 1.0000F) { ...
(假设您将 gap
保留为 float
。)
上述任何解决方案都可以。就个人而言,我会做 gap
一个double
为了让对比更直观,也把对比改成对比0.00001
和 1.0000
.
顺便说一句,E-05
后缀表示“乘以 10 的 -5 次方”(E
代表 Exponent
)。你会看到很多;这是编写浮点常量的标准方法。
关于c - float变量不满足条件(C),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19871086/
我想检索具有多个条件的数据,其中每个条件将在特定字段中包含特定关键字。 表结构如下: sid nid cid 数据 50 7 5 ee 50 7 6 AA 50 7 8 ff 51 7 5 ee 51
在 Prolog 中,我经常通过提供模板(包含变量的结构)然后满足其上的一组约束来解决问题。一个简单的例子可能是: go(T) :- T = [_, _, _], member(cat
在设计 FPGA 系统时,我如何粗略估计给定任务所需的逻辑 block 数量? 有人对我对这些常见设备的期望有一个粗略的数量级吗? 串口 使用 CRC32 的数据包解帧器 8 微核 我看过 www.o
我需要编写一段代码,如果函数满足列表中的大多数元素,则返回 True,不满足其中的 false。例如:moreThan odd [1,2,3] 是 True,但是 moreThan odd [1,2,
一旦满足三个条件,我需要使用 componentWillReceiveProps() 来调用我的组件中的方法。其中两个条件将当前 Prop 与下一个 Prop 进行比较,这两个条件通过 Ajax 请求
我正在构建一个主从表单。主视图模型构造细节 View 模型的实例。这些细节 View 模型有几个依赖项,需要用新 类实例来满足。 (这是因为他们需要在独立于主虚拟机的数据上下文中运行的服务层。) 实现
我有以下项目,我已经使用了一段时间。正如您在运行 snnipets 后看到的那样,一切正常。 /* The dark background behind the dialogs */ .dialog-
我正在尝试找出解决此问题的方法: 我想要一个函数来检查文本字段是否填充了文本并且复选框是否被选中。当满足这些条件时,“提交”按钮将启用。如果启用“提交”按钮后不久,用户清除文本字段或取消选中复选框,则
所以我相对较新,我有以下代码,我想知道如何制作这样我可以返回临时变量,同时满足java的返回要求。我希望返回临时值,但由于它位于 if-else block 内,因此从技术上讲,它不会在其外部初始化。
我正在编写一个脚本,该脚本读取文本文件并根据 .txt 文件的内容更改 div 中的文本。 但这不是我的问题。我不想要纯文本,背景颜色应该根据满足 if/elseif/else 函数的条件而改变。 v
我想在 if let 构造中满足多个约束。我知道我们可以使用“,”(逗号)来解包多个值,但它们都必须成功解包。 例如: var str: String? = "Hello" var x: Int? =
当我在 genymotion 模拟设备上安装我的应用程序时,它无法很好地安装,在控制台上我得到“INSTALL_FAILED_CPU_ABI_INCOMPATIBLE”我尝试了另一个应用程序,它安装得
因此,我试图根据数据帧的匹配条件来查看数据帧的两个变量(v1 和 v2)是否在其符号(正数或负数)中匹配变量(ID1==ID2)。 示例数据框 - Trial.df: ID1 v1
如果交付一个 Java 应用程序,它使用 gradle 依赖管理和许多来自 maven-central 的开源库,是否足以检查第一级 depedencies 的许可证(因为他们的依赖关系必须再次自动与
我正在尝试创建一个满足接口(interface) Iterable 的类“Gprogram” (这样我就可以在我的 Gprogram 中迭代 Gcommand)。但是,我只能使用类型 Iterable
我想知道是否可以获得一些帮助。 我试图在查询中写入一个查询,我使用 3 个字段:ID、选项和金额。 我需要对我的唯一 ID 进行分组,然后在该组中我需要按选项白色进行拆分,总计每个选项的金额。例如:编
如何在iOS swift项目中配置Jitsi-meet框架开启视频通话服务? 最佳答案 编辑:这也适用于 Xcode Version 12.2 (12B45b)在 Mac OS Big Sur 上。
我正在玩一些交互式菜单,目前有一个隐藏菜单,当按下一个按钮时,它会从右边出现,并将整个内容移到上面。有点像移动 facebook 应用程序。为了确定按钮应该将菜单滑出还是放回我使用 javascrip
我的目标很简单,使用遗传算法重现经典的“Hello, World”字符串。 我的代码基于此 post .代码主要包含4个部分: 生成具有多个不同个体的种群 根据与target的比较,定义评估个体好坏的
问题陈述 我们有一个雇主想要面试 N 个人,因此安排了 N 个面试时段。每个人都有这些时段的忙闲时间表。给出一个算法,如果可能的话将 N 个人安排到 N 个槽位,如果不可能则返回一个标志/错误/等。最
我是一名优秀的程序员,十分优秀!