您好,登錄后才能下訂單哦!
小編給大家分享一下LeetCode中兩數(shù)相加的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
給定兩個非空鏈表來代表兩個非負(fù)整數(shù)。數(shù)字最高位位于鏈表開始位置。它們的每個節(jié)點只存儲單個數(shù)字。將這兩數(shù)相加會返回一個新的鏈表。
你可以假設(shè)除了數(shù)字 0 之外,這兩個數(shù)字都不會以零開頭。
如果輸入鏈表不能修改該如何處理?換句話說,你不能對列表中的節(jié)點進(jìn)行翻轉(zhuǎn)。
輸入: (7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)
輸出: 7 -> 8 -> 0 -> 7
由于計算時要保證最右邊的數(shù)對齊,那么很自然的想到先用 棧 存放鏈表中的每個值,然后依次計算。由于相加時可能產(chǎn)生進(jìn)位,所以使用一個 flag 表示是否有進(jìn)位。
提示:若棧中元素相加結(jié)束之后仍有進(jìn)位,則需要新加入一個頭結(jié)點。
1class Solution:
2 def addTwoNumbers(self, l1, l2):
3 # 分別入棧
4 stack1 = []
5 stack2 = []
6 while l1:
7 stack1.append(l1.val)
8 l1 = l1.next
9 while l2:
10 stack2.append(l2.val)
11 l2 = l2.next
12
13 flag = 0
14 head = None
15 while stack1 or stack2 or flag != 0:
16 if stack1:
17 flag += stack1.pop()
18 if stack2:
19 flag += stack2.pop()
20 node = ListNode(flag % 10)
21 node.next = head
22 head = node
23 flag = flag // 10
24 return head
以上是“LeetCode中兩數(shù)相加的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。