JavaScript大整数平方根

danday74

这涉及Chrome和Node v10.4中支持的新JavaScript BigInt类型

以下两行均引发错误:

Math.sqrt(9n)
Math.sqrt(BigInt(9))

错误是:

无法将BigInt值转换为数字

如何在JavaScript中获得BigInt的平方根?TIA

安东

从这里:https : //golb.hplar.ch/2018/09/javascript-bigint.html

function sqrt(value) {
    if (value < 0n) {
        throw 'square root of negative numbers is not supported'
    }

    if (value < 2n) {
        return value;
    }

    function newtonIteration(n, x0) {
        const x1 = ((n / x0) + x0) >> 1n;
        if (x0 === x1 || x0 === (x1 - 1n)) {
            return x0;
        }
        return newtonIteration(n, x1);
    }

    return newtonIteration(value, 1n);
}

sqrt(BigInt(9))

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章