Python連續賦值需要注意的一些問題
在python中是可以使用連續賦值的方式來一次為多個變量進行賦值的,比如:
a = b = c = 1a, b, c = 1, 1, 1
這些都可以完成變量的賦值,但是就有一個問題了,比如:
a = 3a, b = 1, a
如果按照正常的思維邏輯,先進行a = 1,在進行b = a,最后b應該等于1,但是這里b應該等于3,因為在連續賦值語句中等式右邊其實都是局部變量,而不是真正的變量值本身,比如,上面例子中右邊的a,在python解析的時候,只是把變量a的指向的變量3賦給b,而不是a=1之后a的結果,這一點剛開始學python的人可能容易誤解,再舉一個Leetcode里鏈表的例子理解就更深了。
假如要對一個鏈表進行翻轉,就比如把1—>2->3->4轉化為4->3->2->1
對于這個問題很簡單,只要反轉指針就可以了,假如鏈表結構為:
class ListNode: def __init__(self, x):self.val = xself.next = None
我們可以用很簡單的三行代碼完成這個過程:
def reverseList(self, head):L = ListNode(float('-inf'))while head: L.next, head.next, head = head, L.next, head.nextreturn L.next
這里的L是指向一個新建的結點,因為python沒有指針的概念,所以用一個額外的結點來代替頭指針,這里的核心代碼就是中間那一行三個變量的連續賦值,如果單獨一句句來理解的話,最后肯定是想不通的,在這里,假設head結點是鏈表串’1->2->3->4’的頭結點,先用新的L結點的next指針指向head的第一個結點‘1’,之后將L.next(第一次也就是空)賦給了head的next指針,之后再把head的next指針(注意,這里的next指針還是指向‘2’的,而不是空)賦給head,相當于next向前移一位,這一步相當于一個串變成了兩個:
L:‘-inf’->‘1’head:‘2’->‘3’->‘4’->‘5’Python花樣賦值方法總結
#連等賦值a=b=c=1#拆包賦值a,b=1,2#用_占位和*代表不確定個參數進行拆包賦值a=range(10)_,b,c,*d=a#迭代賦值a=(1,2)b=[(i,j)for i in a for j in a]#交換a,b=b,a
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章:
