LintCode:167. 鏈表求和

你有兩個用鏈表代表的整數(shù),其中每個節(jié)點(diǎn)包含一個數(shù)字。數(shù)字存儲按照在原來整數(shù)中相反的順序,使得第一個數(shù)字位于鏈表的開頭。寫出一個函數(shù)將兩個整數(shù)相加,用鏈表形式返回和。
您在真實(shí)的面試中是否遇到過這個題?
樣例

給出兩個鏈表 3->1->5->null 和 5->9->2->null,返回 8->0->8->null

"""
Definition for singly-linked list.
class ListNode:
    def __init__(self, x):
        self.val = x
        self.next = None
"""


class Solution:
    """
    @param: l1: the first list
    @param: l2: the second list
    @return: the sum list of l1 and l2 
    """
    def addLists(self, l1, l2):
        # write your code here
        if l1 is None and l2 is None:
            return None
        
        cur1 = l1.next
        cur2 = l2.next
        head = ListNode((l1.val + l2.val)%10)
        cur = head
        
        carry = (l1.val + l2.val) // 10
        #當(dāng)其中一條鏈表為空的時候,為該鏈表添加一個值為0的節(jié)點(diǎn)
        #直到兩條都為None,這種方式會修改原先的列表.
        while cur1 is not None or cur2 is not None:
            if cur1 is None:cur1 = ListNode(0)
            if cur2 is None:cur2 = ListNode(0)
            
            val = cur1.val + cur2.val + carry
            carry = val // 10
            cur.next = ListNode(val%10)
            
            cur = cur.next
            cur1 = cur1.next
            cur2 = cur2.next
            
        if carry != 0:
            cur.next = ListNode(carry)
        
        return head
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

  • 題目 描述 你有兩個用鏈表代表的整數(shù),其中每個節(jié)點(diǎn)包含一個數(shù)字。數(shù)字存儲按照在原來整數(shù)中相反的順序,使得第一個數(shù)字...
    悠揚(yáng)前奏閱讀 161評論 0 0
  • 分析 注意進(jìn)位
    胡哈哈哈閱讀 504評論 0 0
  • 3.10 69.給出一棵二叉樹,返回其節(jié)點(diǎn)值的層次遍歷(逐層從左往右訪問) 二叉樹的層次遍歷樣例給一棵二叉樹 {3...
    mytac閱讀 1,104評論 3 3
  • 我是小小強(qiáng),這是我的第8篇原創(chuàng)文章,閱讀需要大約10分鐘。 題目 LintCode:鏈表求和 描述 你有兩個用鏈表...
    我叫小小強(qiáng)閱讀 1,030評論 0 0
  • 靜淑: 紐約下雪了,我第一次看見下雪,雪是半夜下的,那時候我還未睡,妹妹跑到我的床前,告訴我下雪了,我起身披...
    林靜風(fēng)閑閱讀 204評論 1 0