python版單鏈表反轉(zhuǎn)
本文實(shí)例為大家分享了python實(shí)現(xiàn)單鏈表反轉(zhuǎn)的具體代碼,供大家參考,具體內(nèi)容如下
代碼如下:
class Node(object): ? ? def __init__(self, elem, next_=None): ? ? ? ? self.elem = elem ? ? ? ? self.next = next_ ? def reverseList(head): ? ? if head == None or head.next==None: ?# 若鏈表為空或者僅一個(gè)數(shù)就直接返回 ? ? ? ? return head? ? ? pre = None ? ? next = None ? ? while(head != None):? ? ? ? ? next = head.next ? ? # 1 ? ? ? ? head.next = pre ? ? # 2 ? ? ? ? pre = head ? ? ?# 3 ? ? ? ? head = next ? ? ?# 4 ? ? return pre if __name__ == '__main__': ? ? l1 = Node(3) ? ?# 建立鏈表3->2->1->9->None ? ? l1.next = Node(2) ? ? l1.next.next = Node(1) ? ? l1.next.next.next = Node(9) ? ? l = reverseList(l1) ? ? print (l.elem, l.next.elem, l.next.next.elem, l.next.next.next.elem)
原始單鏈表:

反轉(zhuǎn)后單鏈表:

反轉(zhuǎn)過程如下:

第一步:next = head.next
將 head.next 賦值給 next 變量,即next 指向了節(jié)點(diǎn)2,先將節(jié)點(diǎn)2 保存起來。
第二步:head.next = pre (初始pre==None)
將 pre 變量賦值給 head.next,即 此時(shí)節(jié)點(diǎn)1 指向了 None
第三步:pre = head
將 head 賦值給了 pre,即 pre 指向節(jié)點(diǎn)1,將節(jié)點(diǎn)1 設(shè)為“上一個(gè)節(jié)點(diǎn)”
第四步:head = next
將 next 賦值給 head,即 head 指向了節(jié)點(diǎn)2,此時(shí)節(jié)點(diǎn)2 設(shè)為“頭節(jié)點(diǎn)”
第一次循環(huán)完畢,進(jìn)入第二次循環(huán),如下圖:

第一步:next = head.next
將 head.next 賦值給 next 變量,即 next 指向了節(jié)點(diǎn)3,先將節(jié)點(diǎn)3 保存起來。
第二步:head.next = pre (此時(shí)的pre已經(jīng)不為None)
將 pre 賦值給 head.next,pre 在上一次循環(huán)的時(shí)候指向了節(jié)點(diǎn)1,那么這一步的意義就是節(jié)點(diǎn)2 指向了 節(jié)點(diǎn)1,完成1和2節(jié)點(diǎn)的反轉(zhuǎn)。
第三步:pre = head
將 head 賦值給了 pre,即 pre 指向節(jié)點(diǎn)2,將節(jié)點(diǎn)2 設(shè)為“上一個(gè)節(jié)點(diǎn)”
第四步:head = next
將 next 賦值給 head,即 head 指向了節(jié)點(diǎn)3。此時(shí)節(jié)點(diǎn)3 設(shè)為“頭節(jié)點(diǎn)”
第二次循環(huán)完畢,以此類推!第三次第四次第五次循環(huán)。最后反轉(zhuǎn)成如下圖

若干注意點(diǎn):
(1)幫助記憶圖:

(2)當(dāng)前頭節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)一定要保存(比如:當(dāng)前頭節(jié)點(diǎn)為2,先將節(jié)點(diǎn)3 保存起來)
(3)實(shí)現(xiàn)反轉(zhuǎn)的key point: head.next = pre
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python+SeaTable實(shí)現(xiàn)生成條形碼圖片并寫入表格
不管是錄入信息時(shí)需要用掃碼器掃碼錄入,還是有別的生成條形碼的需要,這在?SeaTable?表格中用?Python?腳本就可以輕松實(shí)現(xiàn),本文就來為大家詳細(xì)講解一下2022-07-07
Django實(shí)現(xiàn)網(wǎng)頁(yè)分頁(yè)功能
這篇文章主要介紹了Django實(shí)現(xiàn)網(wǎng)頁(yè)分頁(yè)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
Python 把兩層列表展開平鋪成一層(5種實(shí)現(xiàn)方式)
這篇文章主要介紹了Python 把兩層列表展開平鋪成一層(5種實(shí)現(xiàn)方式),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-04-04
Python利用多線程同步鎖實(shí)現(xiàn)多窗口訂票系統(tǒng)(推薦)
這篇文章主要介紹了Python利用多線程同步鎖實(shí)現(xiàn)多窗口訂票系統(tǒng),主要是利用threading.lock()通過實(shí)例代碼相結(jié)合給大家講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12

