两个超大的数字相减

function subtract(f, t) {
    f += '';
    t += '';
    let fl = f.length, tl = t.length, minus = false, minuend = f, subtractor = t, len = tl, maxLen = fl, m, s, currIndex, currT = false, i, sp;
    function reverse(s) {
        return s.split('').reverse();
    }

    if (fl < tl) {
        minus = true;
        minuend = t;
        subtractor = f;
        len = fl;
        maxLen = tl;
    } else if (fl === tl) {
        for (i = 0; i < fl; i++) {
            if (f[i] > t[i]) {
                minus = false;
                minuend = f;
                subtractor = t;
                len = tl;
                maxLen = fl;
                break;
            } else if (f[i] < t[i]) {
                minus = true;
                minuend = t;
                subtractor = f;
                len = fl;
                maxLen = tl;
                break;
            }
        }
    }
    minuend = reverse(minuend);
    subtractor = reverse(subtractor);
    for (i = 0; i < len; i++) {
        m = minuend[i] * 1;
        s = subtractor[i] * 1;
        if (m > s) {
            minuend[i] = m - s;
        } else if (m < s) {
            currIndex = i + 1;
            do {
                if (minuend[currIndex] !== '0') {
                    sp = currIndex - i;
                    minuend[currIndex] = minuend[currIndex] * 1 - 1 + '';
                    currIndex--;
                    for (let j = 0; j < sp; j++) {
                        if (currIndex === i) {
                            minuend[currIndex] = 10 + m - s + '';
                        } else {
                            minuend[currIndex--] = '9';
                        }
                    }
                    currT = false;
                } else {
                    currT = true;
                }
            } while (currT && ++currIndex < maxLen);
        } else {
            minuend[i] = 0;
        }
    }
    minuend = reverse(minuend.join('').replace(/0+$/gi, '')).join('');
    return minus ? '-' + minuend : minuend;
}

声明:严禁抄袭,欢迎转载!不过请带上博文链接!

或者你有更好的实现方式、或者你觉得有可以优化的地方,不妨评论讨论下!觉得得到帮助的可以点个推荐,让更多人也可以得到帮助。

posted @ 2020-05-26 00:02  wuxiexy  阅读(260)  评论(0编辑  收藏  举报
QQ邮箱(欢迎打扰): 781599831@qq.com