JS は 2 つの大きな数値の加算を実装します

2つの数値の値がint型の最大値を超える場合、加算すると精度が崩れますが、文字列であれば精度が崩れないので、1の桁からビット加算することができます。少しずつ、そして最後にそれを綴ります。

function bigIntAdd(x, y) {
    const len = Math.max(x.length, y.length) // 取较长的数为要补0的长度
    // 将数的位数对齐
    x = x.padStart(len, '0')
    y = y.padStart(len, '0')
    let flag = '0' // 记录每个位相加时要进的位
    const queue = [] // 存储结果
    // 倒序从个位开始逐位相加
    for (let i = len - 1; i >= 0; i--) {
        const charX = x.charAt(i)
        const charY = y.charAt(i)
        // 求和时要加上上一次的进位
        const sum = Number(charX) + Number(charY) + Number(flag)
        // 十进制加法满十进一 判断是否要进1位 不进位则为0
        flag = sum >= 10 ? '1' : '0'
        // 取模得到当前位存入
        queue.unshift(sum % 10)
    }
    // 计算完毕后判断最高位是否产生了进位 如果产生了进位则补1
    if (flag === '1') {
        queue.unshift('1')
    }
    // 返回字符串表示形式
    return queue.join('')
}
console.log(bigIntAdd('1234567899999999999', '1')) // 1234567900000000000
console.log(bigIntAdd('9999999999999999999', '1111111111111111111')) // 11111111111111111110

おすすめ

転載: blog.csdn.net/Suk__/article/details/131748129