非常に大きい数値または非常に小さい数値の場合、浮動小数点値は科学表記法で表すことができます。科学的表記法を使用すると、次のように数値に e/E を加え、その後に 10 の倍数を続けて数値を表すことができます。
var num1 = 3.125e7; // 31250000 var num2 = 3e-17; // 0.0000000000000003
特に大きな数値の加算と減算を実行するには、次のような文字列科学表記法を使用できます。
// ここでは大きな整数のみが考慮され、小数は考慮されません function strAdd(sNum1, sNum2){
/*最上位の桁が 1 つ進んだ状況を記録するには 1 桁追加します*/
var sNum1 = ['0', sNum1].join(''), sNum2 = ['0', sNum2].join('');
/*短い数値文字列には0を追加します*/
var len1 = sNum1.length、len2 = sNum2.length、
ZeroArr = function(len){
var arr = 新しい配列(len)、i=len
While(i--){arr[i] = 0;}
戻り値
};
if(len1 > len2){
var arrTemp = zeroArr(len1 - len2);
arrTemp.push(sNum2)、
sNum2 = arrTemp.join('');
}
else if(len2 > len1){
var arrTemp = zeroArr(len2 - len1);
arrTemp.push(sNum1)、
sNum1 = arrTemp.join('');
}
/*文字列を配列に変換し、対応する数字を追加します*/
var arr1 = sNum1.split('')、arr2 = sNum2.split('');
var arrAddRes = 新しい配列(arr1.length)、i=arr1.length;
var andone = 0, // 下位ビットに 1 を加算するかどうか cur1, cur2, curAdd;
while(i--){
Cur1 = arr1[i]、cur2 = arr2[i]
CurAdd = cur1 cur2 andone
If(10 > curAdd)
arrAddRes[i] = curAdd,
アンドワン = 0;
それ以外
arrAddRes[i] = curAdd.toString().slice(1,2),
アンドワン = 1;
}
If(!andone){ // 最後に 1 を追加するか、そうでない場合は前の 0 をインターセプトするかどうか arrAddRes.splice(0,1);
}
/*配列の最初の 19 桁がインターセプトされた場合は、科学的表記法を使用して結果を表現します*/
var keeplen = 19; // JS の小数点は小数点以下 18 桁のみを保持します var eAfter = arrAddRes.length - 1; // e の後の倍数部分 var eBefore, eBeforeStr = ''; // e の前の小数部分>
if(keeplen < arrAddRes.length)
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1, keeplen).join('')].join('');
それ以外
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1).join('')].join('');
eBefore = eBeforeStr;
Return [Number(arrAddRes.join('')), eBefore, eAfter];
}
strAdd('1234567890', '9876543210'); // -> [1111111100, 1.1111111, 9]
コードは上記の通りですが、とても簡単ですか?