- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
如果我想检查正 float A 是否小于另一个正 float B 的平方反比(在 C99 中),如果 B 非常小,会不会出错?
我可以想象像检查它一样
if(A<1/(B*B))
但是如果 B 足够小,这会导致无穷大吗?如果发生这种情况,代码是否仍能在所有情况下正常工作?
同样的道理,我可能会这样做
if(1/A>B*B)
...这可能会稍微好一点,因为如果 B 很小,B*B 可能为零(这是真的吗?)
最后一个我想不到是错的解决方案是
if(sqrt(1/A)>B)
我认为这不会导致除法为零,但如果 A 接近于零,仍然可能会出现问题。
所以基本上,我的问题是:
编辑:对于那些想知道的人,我最终做了
if(B*A*B<1)
我是按这个顺序做的,因为从视觉上看,哪个乘法先出现是明确的。
最佳答案
如果您想处理 A
的整个可能值范围和 B
, 那么你需要小心一点,但这真的不太复杂。
使用建议a*b*b < 1.
是个好人;如果b
太小了 a*b*b
下溢为零,然后 a
一定小于1./(b*b)
.相反,如果 b
太大了 a*b*b
溢出到无穷大,则条件将(正确地)不满足。 (Potatoswatter 在另一篇文章的评论中正确地指出,如果您编写 b*b*a
,这不能正常工作,因为 b*b
可能会溢出到无穷大,即使如果 a
恰好是非正规的,条件应该为真。但是,在 C 中,乘法从左到右关联,因此如果您编写 a*b*b
并且您的平台遵循合理的数字模型,这不是问题。 )
因为您先验知道 a
和 b
都是正数,a*b*b
没办法生成 NaN,因此您不必担心这种情况。上溢和下溢是唯一可能的不当行为,我们已经对它们进行了说明。如果您需要支持 a
的情况或 b
可能为零或无穷大,那么您需要更加小心。
回答您的直接问题:(答案采用 IEEE-754 算法)
Can 1/X ever be infinity if X is greater than zero (but small)?
是的!如果 x 是一个小的正非正规值,则 1/x
可以溢出并产生无穷大。例如,在默认舍入模式下的 double 中,1 / 0x1.0p-1024
会溢出。
Can X*X ever be zero if X is greater than zero?
是的!在默认舍入模式下的 double 中,x 的所有值都小于 0x1.0p-538
(即 C99 十六进制格式的 2**-578
)左右具有此属性。
Will comparisons with infinity work the way I would expect them to?
是的!这是 IEEE-754 的最佳特性之一。
关于除以 1/一个非常小的 float 时会发生坏事吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2954560/
你有没有注意到 Excel Vba 代码中除法 2/60 的问题?我正在使用 Excel 2013。请测试以下代码: Sub test1() Dim A As Integer Dim B As Int
我正在运行长时间的模拟。我将结果记录到 vector 中以计算有关数据的统计信息。我意识到,理论上,这些样本可能是除以零的结果。这只是理论上的,我很确定事实并非如此。为了避免修改代码后重新运行模拟,我
我有一些可以包含字母、数字和“#”符号的字符串。 我想删除除以“#”开头的单词以外的数字 下面是一个例子: "table9 dolv5e #10n #dec10 #nov8e 23 hello" 预期
我有以下代码,问题是我尝试将 Double 除以 Int factorial :: Int -> Int factorial 0 = 1 factorial e = e * (factorial e-
我有以下查询,它试图计算出某种产品占产品总数的百分比。 IE:[产品数量]/[产品总数] = 百分比 ;WITH totalCount AS( SELECT CAST(COUN
我正在解析字符串,然后需要将其转换为数字。但如果它包含除以 0 的例子 String str1 = "1+2+3-5/0+4+6" String str2 = "1+2+3-4/0.000 +4+6"
这个问题已经有答案了: Right Shift to Perform Divide by 2 On -1 (6 个回答) 已关闭 9 年前。 在阅读 Collections.reverse 的 Jav
我是 C++ 新手。我听说除以0会导致运行时错误,但是当我尝试时,它抛给我一个编译器错误C2124并且没有创建目标文件,所以编译器会自动运行代码以查看它是否可以在创建之前执行目标文件? (顺便说一句,
我试图在 codefights.com 上解决这个问题,方法是找出最大的质因数并将该数字除以质因数的幂。 int highestPower(int N, int A) { int B =A, j=0,
我对在不同计算机上运行程序有疑问。 我用 C++\windows 7 64 位\Visual Studio 编写了一个程序,该程序在我的计算机上完美运行。 当我尝试在另一台计算机(Windows 7
这个问题已经有答案了: Division in C++ not working as expected (6 个回答) 已关闭 9 年前。 Helo,我是编程新手,遇到了一个问题,我有一个整数,例如
我正在做某事,但遇到了一个我不明白的问题。 double d = 95.24 / (double)100; Console.Write(d); //Break point here 控制台输出是 0.
我需要仅使用按位运算符(例如 ! & ^ ~ 和移位)来计算数字 (a/(2**b)。我得到了以下提示,但我是 C 新手,我不知道什么是代码含义: int bias = x>0 ? 0 : ((1>b
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Java Integer division: How do you produce a double? 当我
嗨,我正在尝试将 numpy 数组分成两部分,并在一个循环中进行此操作,例如: main_array.shape = (50, 400, 400, 3) for i = 0: sub_array_1
这是片段: String myTime = someTime / 1e9d + ","; someTime 是使用 System.nanoTime() 派生的。 1e9d 在这里做什么? 最佳答案 1
Random random = new Random(); int randomx = random.Next(0, 240); 这是我获取随机数的方式,从 0 到 240,如何才能只获取除以 5 的
我一直在处理一个应用程序,因为图像表现得很奇怪,所以我决定打开 Wall 标志,看看是否有任何奇怪的事情发生。它揭示了一个新的警告: character.cpp(364): warning C4723
我是 Android Studio 的新手,我正在开发一个计算器应用程序。现在,当我除以零时,自然会收到错误消息“Infinity”,但如果我想将其更改为“不能除以零”,我该怎么做呢? impor
如何显示每 5 日创建一个新行的表中的数据 ? 例子 data: [1,2,3,4,5,6]; 成分: {{item}} 预期的: | 1 | 2 | 3 | 4 | 5 | | 6 |
我是一名优秀的程序员,十分优秀!