2 兩數相加 python

2021-09-14 00:19:21 字數 1279 閱讀 1611

題目:兩個非空鍊錶表示兩個非負整數,逆序儲存,將兩鍊錶表示的數相加,返回乙個新的逆序鍊錶

法:兩數加法,只是用鍊錶逆序表示,相當於頭節點是個位數字,後面依次是十位、百位數等

注意:1)考慮進製,尤其是最後一次的進製,當兩個鍊錶都遍歷完之後如果還有進製,再在尾部增加乙個節點

2)要記得每次移動指標,避免陷入死迴圈

def addtwonumbers(self, l1, l2):

if l1==none:return l2

if l2==none:return l1

p,q=l1,l2

res=listnode(0)

head,carry=res,0

while p!=none or q!=none:

tmp=0

if p:

tmp+=p.val

p=p.next

if q:

tmp+=q.val

q=q.next

tmp+=carry

carry=tmp//10

tmp%=10

head.next=listnode(tmp)

head=head.next

if carry:

head.next=listnode(carry)

return res.next

其實**可以寫的稍簡潔一點,將進製carry放到一開始的大迴圈while中去

def addtwonumbers(self, l1, l2):

""":type l1: listnode

:type l2: listnode

:rtype: listnode

"""res=listnode(0)

p,q,tmp=l1,l2,res

carry=0

while p!=none or q!=none or carry!=0:

num=0

if p!=none:

num+=p.val

p=p.next

if q!=none:

num+=q.val

q=q.next

num+=carry

carry=num//10

num%=10

tmp.next=listnode(num)

tmp=tmp.next

return res.next

2 兩數相加

平均星級 4.45 239次評分 2018年2月2日 28.6k次 預覽 給定兩個非空鍊錶來表示兩個非負整數。位數按照逆序方式儲存,它們的每個節點只儲存單個數字。將兩數相加返回乙個新的鍊錶。你可以假設除了數字 0 之外,這兩個數字都不會以零開頭。示例 輸入 2 4 3 5 6 4 輸出 7 0 8 ...

2 兩數相加

給定兩個非空鍊錶來表示兩個非負整數。位數按照逆序方式儲存,它們的每個節點只儲存單個數字。將兩數相加返回乙個新的鍊錶。你可以假設除了數字 0 之外,這兩個數字都不會以零開頭。示例 輸入 2 4 3 5 6 4 輸出 7 0 8原因 342 465 807 definition for singly l...

2 兩數相加

給定兩個非空鍊錶來表示兩個非負整數。位數按照逆序方式儲存,它們的每個節點只儲存單個數字。將兩數相加返回乙個新的鍊錶。你可以假設除了數字 0 之外,這兩個數字都不會以零開頭。示例 輸入 2 4 3 5 6 4 輸出 7 0 8 原因 342 465 807演算法 我們首先從最低有效位也就是列表 l1和...