- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
如果一个 float 重复乘以一个小于一的数, float 是否可能变为零?
这是一个例子:
float number = 1.0f;
for ( int i = 0; i < ONE_BILLION; ++i )
{
number *= 0.01f;
}
但请不要将您的答案局限于示例。
谢谢!
最佳答案
是的,当乘法的结果小于最接近零的可表示数时,它将变为零。对于 IEEE float ,任何小于或等于 0.5f
(但大于零)的乘数都会发生这种情况;但是,如果乘数甚至略大于 0.5f
(例如,0.5f + FLT_EPSILON
),结果将收敛到最小的可表示正数并永远保持在那里。比较使用和不使用 -DGREATER
时此程序的行为:
#include <stdio.h>
#include <float.h>
#ifdef GREATER
#define MULTIPLIER (0.5f + FLT_EPSILON)
#else
#define MULTIPLIER 0.5f
#endif
int
main(void)
{
float x = 1.0f;
unsigned int count = 0;
while (x > 0.0f && count < 200)
{
x *= MULTIPLIER;
printf("%g %a\n", x, x);
count++;
}
return 0;
}
关于c++ - C/C++ : Float Arithmetic Question,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4697540/
我阅读了以下问题:Value of i for (i == -i && i != 0) to return true in Java并留下了微微的眼花。 一读到spacecraft being los
我试图记住 Javascript 中称为“发条算术”的东西,我很久以前在有关幻灯片/轮播的教程中读过它。 (术语可能有误,因为我在谷歌中找不到任何有用的东西) 它是以下代码的简写: a = a + 1
我想知道类型转换在实践中是如何在类型之间进行的(在“嵌入式”C 中)。例如:如果我有一个 Signed 16-bit 数字,值为 -80d,11010000b,我想将它转换为 无符号 16 位。我
题目地址:https://leetcode.com/problems/arithmetic-slices/description/ 题目描述 Asequence of number is call
假设我有以下 data.frame 由多行(此处未全部显示)和 31 列组成。第一个(并且应该保留)标记为“gene_ID”,从第二个一直到第 30 列,它们都有奇怪的名称,如下所示: |gene_
我正在尝试从 Sightly 列表中的项目总数中减去 2。 ${itemList.size -2 @ context='number'} 结果是: org.
接听时this问题 我尝试运行此代码(用于生成给定范围内的随机数); #include #include #include #include int main() { int max_r
虽然至少从手波的角度来看,我相信我知道“算术运算符”是什么,但我正在寻找一个正式的定义。我检查了 C17 标准文档,但找不到这样的定义,尽管它在多个地方使用了术语“算术运算符”。 我能找到的最接近的是
您好,我正在使用 SFML 开发游戏,但我遇到了函数问题。 这是代码: 敌人.h: #ifndef ENEMY_H #define ENEMY_H #include c
在惯用的 C 风格中,可以使用两个参数以一种简单的方式实现快速排序: void quicksort(int inputArray[], int numelems); 我们可以通过指针算法安全地使用两个
众所周知,我们可以通过算术表达式在SQL语句中进行计算。算术表达式可以包含列名、数值和算术运算。以下是 SQL 语句语法: SELECT [arithmetic operator]... FROM [
如何解决这些警告? // midiNote is a double as it is used in floating point equation // v is int because that'
我正在使用提示创建一个基本计算器。用户输入一个数字、一个操作数和另一个数字,这将为他们提供正确的答案。 问题:无论使用哪种运算符,我的号码都在成倍增加。例如,输入 5+5 得到的值是 25。 为什么我
如果我有定义: typedef struct y_t *Y; 和 typedef struct x_t *X; struct x_t { Y *b; Y a; int s
我正在使用 Android 工具链编译 Android 内核。在驱动程序内部,我需要使用 double 算术,但是当我编译时,我会遇到很多错误,每次使用 double 类型时都会出现一个错误。例如我得
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我需要有关 JSP 中以下 EL 代码段的说明 $ {5/x} : ${5/x} $ {10/0} : ${10/0} $ {5/2} : ${5/2} $ {x/10} : ${x/10} $ {5
我正在尝试编写一个包含小于或大于的脚本,但它给了我以下错误消息:语法错误:需要算术表达式请告知下面的代码示例: x=1 for ($x -lt 21) -- I tried the fo
我正在尝试编写一个程序来执行简单的算术运算。我想让程序提示用户输入两个数字,然后计算出五个结果: 总和 区别 产品 两个整数的商 浮点除法。 现在,我记得在 Python 2 中,通常有用于字符串的
我一直在努力理解这个程序的输出: #include int main(){ static int arr[] = {0, 1, 2, 3, 4}; int *p[] = {ar
我是一名优秀的程序员,十分优秀!