javascript – 确定浮点数中前导零的数量
作者:互联网
如何计算小数点后但在浮点数中第一个非零之前有多少个零.例子:
0 -> 0
1 -> 0
1.0 -> 0
1.1 -> 0
1.01 -> 1
1.00003456 ->4
直觉上我假设有一个数学函数提供这个,或者至少是主要部分.但我既不记得也不知道哪一个.
我知道可以通过首先将数字转换为字符串来完成,只要数字不是科学记数法,但我想要一个纯数学解决方案.
在我的情况下,如果这是一个复杂的问题,我不需要一些适用于负数的东西.
无论语言如何,我想知道一般的方法是什么.
但如果有一个非常标准的数学函数,我也想知道JavaScript是否具有此功能.
作为旁注,我想知道这个计算是否与确定整数的十进制表示所需的位数的方法有关.
解决方法:
设x是一个非整数,可以写成整个部分的n个数字,然后是小数点,然后是m,然后是小数部分的其余部分.
x = [a1a2…an] . [0102…0m][b1b2…bm]
这意味着x的小数部分大于或等于10-m,小于10-m 1.
换句话说,x的小数部分的十进制对数大于或等于-m,并且小于-m 1.
反过来,这意味着x的小数部分的十进制对数的整个部分等于-m.
function numZeroesAfterPoint(x) {
if (x % 1 == 0) {
return 0;
} else {
return -1 - Math.floor(Math.log10(x % 1));
}
}
console.log(numZeroesAfterPoint(0));
console.log(numZeroesAfterPoint(1));
console.log(numZeroesAfterPoint(1.0));
console.log(numZeroesAfterPoint(1.1));
console.log(numZeroesAfterPoint(1.01));
console.log(numZeroesAfterPoint(1.00003456));
As a sidenote, I wonder if this calculation is related to the method for determining how many digits are required for the decimal representation of an integer.
以相同的方式,当且仅当n-1 <= log10(x)<1时,正整数x取n个十进制数来表示它. ñ. 因此x的十进制表示中的位数是floor(log10(x))1. 也就是说,我不建议使用这种方法来确定实际的位数. log10不能保证给出对数的精确值(甚至不像IEEE 754允许的那样精确),这可能会导致某些边缘情况下的结果不正确.
标签:javascript,algorithm,floating-point,math,language-agnostic 来源: https://codeday.me/bug/20190727/1551212.html