JavaScript は多数の Operations_JavaScript スキルを実装します

WBOY
リリース: 2016-05-16 16:30:23
オリジナル
2112 人が閲覧しました

非常に大きい数値または非常に小さい数値の場合、浮動小数点値は科学表記法で表すことができます。科学的表記法を使用すると、次のように数値に 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]



コードは上記の通りですが、とても簡単ですか?
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート