亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript 大數(shù)據(jù)相加的問(wèn)題

 更新時(shí)間:2011年08月03日 23:16:56   作者:  
寫(xiě)一個(gè)函數(shù)處理大數(shù)據(jù)的相加問(wèn)題,所謂的大數(shù)據(jù)是指超出了整型,長(zhǎng)整型之類(lèi)的常規(guī)數(shù)據(jù)類(lèi)型表示范圍的數(shù)據(jù)。實(shí)現(xiàn)語(yǔ)言不限。
同樣是一道面試題,來(lái)自有道前端的面試。
寫(xiě)一個(gè)函數(shù)處理大數(shù)據(jù)的相加問(wèn)題,所謂的大數(shù)據(jù)是指超出了整型,長(zhǎng)整型之類(lèi)的常規(guī)數(shù)據(jù)類(lèi)型表示范圍的數(shù)據(jù)。實(shí)現(xiàn)語(yǔ)言不限。
我是用js實(shí)現(xiàn)的,說(shuō)一下我自己的思路:
1、首先這個(gè)題目最重要的環(huán)節(jié)在考慮怎么存儲(chǔ)大數(shù)據(jù)?用什么數(shù)據(jù)類(lèi)型保存呢?最簡(jiǎn)單可行的方式是String
2、確定了使用何種類(lèi)型保存數(shù)據(jù)之后這個(gè)題目就明朗了。首先判斷兩個(gè)傳入字符串的長(zhǎng)度,取最短的len循環(huán),兩者從低位開(kāi)始對(duì)應(yīng)位相加,同時(shí)注意保存進(jìn)位。在短的數(shù)據(jù)處理完后,將進(jìn)位交給較長(zhǎng)串的剩余部分處理。
詳細(xì)實(shí)現(xiàn)看一下代碼,完整實(shí)例見(jiàn)jsfiddle
復(fù)制代碼 代碼如下:

var strAdd = function(srcA, srcB) {
var i, temp, tempA, tempB, len, lenA, lenB, carry = 0;
var res = [],
arrA = [],
arrB = [],
cloneArr = [];
arrA = srcA.split('');
arrB = srcB.split('');
arrA.reverse();
arrB.reverse();
lenA = arrA.length;
lenB = arrB.length;
len = lenA > lenB ? lenB : lenA;
for (i = 0; i < len; i++) {
tempA = parseInt(arrA[i], 10);
tempB = parseInt(arrB[i], 10);
temp = tempA + tempB + carry;
if (temp > 9) {
res.push(temp - 10);
carry = 1;
} else {
res.push(temp);
carry = 0;
}
}
cloneArr = lenA > lenB ? arrA : arrB;
for (; i < cloneArr.length; i++) {
tempA = parseInt(cloneArr[i], 10);
temp = tempA + carry;
if (temp > 9) {
res.push(temp - 10);
carry = 1;
} else {
res.push(temp);
carry = 0;
}
}
return (res.reverse()).join('');
};

以上。
PS:其實(shí)吧,這個(gè)面試題被我改編了下,原始的面試題主考官提示了用字符串保存大數(shù)據(jù)的,這個(gè)其實(shí)降低難度了~~

相關(guān)文章

最新評(píng)論