2. Add Two Numbers 鏈表表示的兩數(shù)求和

You are given two linked lists representing two non-negative numbers. The digits are stored in reverse order and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.
Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
Output: 7 -> 0 -> 8
給定兩個(gè)代表兩個(gè)非負(fù)數(shù)的鏈表,按數(shù)位逆置方式存儲(chǔ)(即123存儲(chǔ)為3→2→1→NULL),要求返回兩數(shù)之和的鏈表迄本。


思路:
【方法1】將兩個(gè)鏈表轉(zhuǎn)換為整數(shù)聘萨,相加后再轉(zhuǎn)換為鏈表返回,需要注意int型表示的范圍朦促,必要時(shí)需要使用long int或longlong犬钢;

class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        if(!l1 || !l2)  return(!l1)?l2:l1;

        long int n1=0,n2=0,n3=0,digit=0,count=1;
        ListNode *p=l1;
        while(p){
            digit=p->val;
            n1=n1+digit*count;
            p=p->next;
            count*=10;
        }
        p=l2;
        count=1;
        while(p){
            digit=p->val;
            n2=n2+digit*count;
            p=p->next;
            count*=10;
        }

        n3=n1+n2;
        ListNode *res=new ListNode(n3%10);
        n3/=10;
        p=res;
        for(;n3>0;n3/=10){
            ListNode *tmp=new ListNode(n3%10);
            p->next=tmp;
            p=tmp;
        }
        p->next=nullptr;
        return res;
    }
};

【方法2】直接在鏈表上進(jìn)行處理,由于鏈表是逆序數(shù)位存儲(chǔ)思灰,相當(dāng)于整數(shù)右對(duì)齊加法玷犹,相加時(shí)注意進(jìn)位以及兩數(shù)位數(shù)不一致的情況。
兩種方法相比較而言方法1較為簡(jiǎn)單洒疚,但處理位數(shù)受限歹颓,耗時(shí)較長(zhǎng)。

ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    ListNode *head = NULL, *prev = NULL;
    int carry = 0;
    while (l1 || l2) {
        int v1 = l1? l1->val: 0;
        int v2 = l2? l2->val: 0;
        int tmp = v1 + v2 + carry;
        carry = tmp / 10;
        int val = tmp % 10;
        ListNode* cur = new ListNode(val);
        if (!head) head = cur;
        if (prev) prev->next = cur;
        prev = cur;
        l1 = l1? l1->next: NULL;
        l2 = l2? l2->next: NULL;
    }
    if (carry > 0) {
        ListNode* l = new ListNode(carry);
        prev->next = l;
    }
    return head;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末油湖,一起剝皮案震驚了整個(gè)濱河市巍扛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌乏德,老刑警劉巖撤奸,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吠昭,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡胧瓜,警方通過(guò)查閱死者的電腦和手機(jī)矢棚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)府喳,“玉大人蒲肋,你說(shuō)我怎么就攤上這事《勐” “怎么了兜粘?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)弯蚜。 經(jīng)常有香客問(wèn)我孔轴,道長(zhǎng),這世上最難降的妖魔是什么碎捺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任距糖,我火速辦了婚禮,結(jié)果婚禮上牵寺,老公的妹妹穿的比我還像新娘悍引。我一直安慰自己,他們只是感情好帽氓,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布趣斤。 她就那樣靜靜地躺著,像睡著了一般黎休。 火紅的嫁衣襯著肌膚如雪浓领。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,274評(píng)論 1 300
  • 那天势腮,我揣著相機(jī)與錄音联贩,去河邊找鬼。 笑死捎拯,一個(gè)胖子當(dāng)著我的面吹牛泪幌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播署照,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼祸泪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了建芙?” 一聲冷哼從身側(cè)響起没隘,我...
    開(kāi)封第一講書(shū)人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎禁荸,沒(méi)想到半個(gè)月后右蒲,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體阀湿,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年瑰妄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了陷嘴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡翰撑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出啊央,到底是詐尸還是另有隱情眶诈,我是刑警寧澤,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布瓜饥,位于F島的核電站逝撬,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏乓土。R本人自食惡果不足惜宪潮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望趣苏。 院中可真熱鬧狡相,春花似錦、人聲如沸食磕。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)彬伦。三九已至滔悉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間单绑,已是汗流浹背回官。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搂橙,地道東北人歉提。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像区转,于是被迫代替她去往敵國(guó)和親唯袄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容