Untuk nombor yang sangat besar atau sangat kecil, nilai titik terapung boleh diwakili dalam tatatanda saintifik. Menggunakan tatatanda saintifik, nombor boleh dinyatakan sebagai nombor tambah e/E, diikuti dengan gandaan 10, seperti:
var num1 = 3.125e7; // 31250000 var num2 = 3e-17;
Untuk melakukan penambahan dan penolakan nombor yang besar, anda boleh menggunakan tatatanda saintifik rentetan, seperti:
// Hanya integer besar dipertimbangkan di sini, perpuluhan tidak dianggap fungsi strAdd(sNum1, sNum2){
/*Tambah satu digit untuk merekodkan situasi di mana digit tertinggi dimajukan sebanyak satu*/
var sNum1 = ['0', sNum1].join(''), sNum2 = ['0', sNum2].join('');
/*Tambah 0 pada rentetan angka pendek*/
var len1 = sNum1.length, len2 = sNum2.length,
ZeroArr = fungsi(len){
var arr = Array(len), i=len;
Manakala(i--){arr[i] = 0;}
Kembali arr;
};
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('');
}
/*Tukar rentetan kepada tatasusunan dan tambah digit yang sepadan*/
var arr1 = sNum1.split(''), arr2 = sNum2.split('');
var arrAddRes = Array baharu(arr1.length), i=arr1.length
var andone = 0, // Sama ada hendak menambah satu pada bit rendah cur1, cur2, curAdd
manakala(i--){
Cur1 = arr1[i], cur2 = arr2[i];
CurAdd = cur1 cur2 andone
Jika(10 > curAdd)
arrAddRes[i] = curAdd,
andone = 0;
lain
arrAddRes[i] = curAdd.toString().slice(1,2),
andone = 1;
}
If(!andone){ // Sama ada hendak menambah satu pada penghujung, jika tidak memintas 0 arrAddRes.splice(0,1) sebelumnya
}
/*Jika 19 digit pertama tatasusunan dipintas, gunakan tatatanda saintifik untuk menyatakan keputusan*/
var keeplen = 19; // Perpuluhan JS hanya menyimpan 18 digit selepas titik perpuluhan var eAfter = arrAddRes.length - 1; // Bahagian berbilang selepas e var eBefore, eBeforeStr = ''; >
if(keeplen < arrAddRes.length)
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1, keeplen).join('')].join('');
lain
eBeforeStr = [arrAddRes[0], '.', arrAddRes.slice(1).join('')].join('');
eBefore = eBeforeStr
Kembalikan [Number(arrAddRes.join('')), eSebelumnya, eAfter];
}
strAdd('1234567890', '9876543210'); // ->
Kod adalah seperti di atas, adakah ia sangat mudah?