- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想找到一种有效的方法来确保小数位数双不超过三。
double num1 = 10.012; //True
double num2 = 10.2211; //False
double num2 = 10.2; //True
目前,我所做的只是使用正则表达式拆分和计数索引。像下面这样。
String[] split = new Double(num).toString().split("\\.")
split[0].length() //num of decimal places
有没有一种有效或更好的方法来做到这一点,因为我会调用它功能很多吗?
最佳答案
如果您想要一个解决方案,以一种与将 double 转换为字符串的最终结果相一致的方式告诉您该信息,那么效率并没有真正发挥作用;你基本上必须转换为字符串并检查。结果是, double 型完全有可能包含一个在数学上(例如)万位中具有(例如)非零值的值,但在转换为字符串时则不会。这就是 IEEE-754 double 二进制浮点的乐趣:从字符串表示中获得的位数仅是区分该值与其相邻可表示值所需的位数。来自 the Double
docs :
How many digits must be printed for the fractional part of m or a? There must be at least one digit to represent the fractional part, and beyond that as many, but only as many, more digits as are needed to uniquely distinguish the argument value from adjacent values of type
double
. That is, suppose that x is the exact mathematical value represented by the decimal representation produced by this method for a finite nonzero argument d. Then d must be thedouble
value nearest to x; or if twodouble
values are equally close to x, then d must be one of them and the least significant bit of the significand of d must be0
.
但是如果您不关心这一点,并且假设将值范围限制为 long
是可以的,那么您可以执行以下操作:
private static boolean onlyThreePlaces(double v) {
double d = (double)((long)(v * 1000)) / 1000;
return d == v;
}
...它的内存开销应该比 String
往返要少。
但是,如果该方法和 Double.toString(double)
的结果没有出现相当多的次数,我会感到惊讶出于上述原因,按小数点后的数字进行匹配。
在对该问题的评论中,您说过(当我询问值范围时):
Honestly I'm not sure. I'm dealing with prices; For starters, I'll assume 0-200K
使用double
来表示财务值通常不是一个好主意。如果由于内存问题您不想使用 BigDecimal,请选择您的精度并根据您的值范围使用 int 或 long 。例如,如果您只需要精确到便士的精度,则可以使用乘以 100 的值(例如,2000 是 Ⓠ20 [或者您使用的任何货币,我使用 Ⓠ 表示 quatloos ])。如果您需要精确到千分之一(如您的问题所示),请乘以 100000(例如,2000000 是 Ⓠ20)。如果您需要更高的精度,请选择更大的乘数。即使您达到万分之一便士(乘数:10000000),使用 long
,您的范围也为 Ⓠ-922,337,203,685 到 Ⓠ922,337,203,685。
这有一个额外的好处,它使检查更容易:只需一个直接的 %
。如果您的乘数是 10000000(一分钱的十万分之一),则只需 value % 10000 != 0
来识别无效乘数(或 value % 10000 == 0
来识别有效)。
long num1 = 100120000; // 10.012 => true
// 100120000 % 10000 is 0 = valid
long num2 = 102211000; // 10.2211 => false
// 102211000 % 10000 is 1000 = invalid
long num3 = 102000000; // 10.2 => true
// 102000000 % 10000 is 0 = valid
关于java - 查找 double 值的小数位数的有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44370395/
下面的代码有效,我觉得double(double)和double(*)(double)没有区别,square和 &square,我说得对吗? #include double square(doubl
我知道我的作业很草率,这是我在这门课上的第 4 次作业。任何帮助将不胜感激,谢谢。 double getPrincipal(0); double getRate(0); double getYe
我遇到了那个错误,当我使用类时,我在使用函数指针时遇到了这个错误。我的函数'ope'函数我该如何解决 evaluator::function(){ double (*ope) (dou
问题://故事从哪里开始 Graphics 类型中的方法 drawLine(int, int, int, int) 不适用于参数 (double, double, double, double) g.
我有一张 map> m1 形式的 map .我可以将其复制到 map m2 形式的 map 吗?这样键是相同的,并且 m2 中的值是 get(m1->second) 不使用循环?谢谢! 最佳答案 这样
有没有办法获取vector> 的“.first”和“.second”的连续内存? ?我的意思是: void func(int N, double* x, double* y) { for (i
我正在尝试将自定义 lambda 传递给需要函数指针的函数(更准确地说是 zero 中的 Brent library 函数)。 我的想法是,我将使用参数创建一次 lambda,然后用多个值对其求值 x
这是一个很简单的问题,让我很困惑。 我收到一个源文件的以下错误,但另一个没有: 4 src/Source2.cpp:1466: error: no matching function for cal
struct CalculatorBrain { private var accumulator: Double? func changeSign(operand: Double) -
在我正在进行的项目中,我尝试使用 curlpp库来发出一个简单的 html GET 请求。当我将 cpp 文件传递给 g++ 时,出现以下错误: /usr/local/include/curlpp
不使用double就能获得quadruple精度超过16位的数字吗?如果可能的话,这取决于编译器还是其他?因为我知道有人说他使用double精度,并且具有22位精度。 最佳答案 数据类型double
我正在寻找有关特斯拉 GPU 中硬件如何实现 double 的信息。我读到,两个流处理器正在处理单个 double 值,但我没有找到 nvidia 的任何官方论文。 提前致谢。聚苯硫醚为什么大多数 G
这个问题在这里已经有了答案: Passing capturing lambda as function pointer (10 个答案) 关闭 2 年前。 我有这个错误 error: cannot
情况:我有一个元组列表,其中添加了一个元组: List> list = new List>(); list .Add(new Tuple(2.2, 6.6)); 一切似乎都还好。但是......在 D
我有一个 JList,里面有一堆名字,还有一个包含这些名字值的数组 final Double[] filmcost = { 5.00, 5.50, 7.00, 6.00, 5.00 }; 我想做的是,
我试图找出牛顿法来求方程的根。这个错误出来了,我无法处理。 double fn(double n){ return sin(n)+log(n)-1; } double f1n(double n
我有一个 junit 测试断言两个 Double 对象,具有以下内容: Assert.assertEquals(Double expected, Double result); 这很好,然后我决定将其
我正在尝试引入部分数据文件来填充数组,用户尝试了三次输入正确的数据文件名。我一再遇到这些错误。我知道像 arr 这样的数组只是一个指向内存块的指针。 #include #include #incl
我正在尝试完成复习题(为即将到来的编程决赛),但是,我无法解决这个问题,因为我不断收到错误(标题)。正如预期的那样,我将发布问题和我尝试的解决方案。 问题: 给定以下函数定义:void swap(do
任何人都知道如何实现这一目标。我已经尝试了通常的公式,但我只得到正数 Double.NEGATIVE_INFINITY) return d; } } 这将以相同的概率
我是一名优秀的程序员,十分优秀!