python版單鏈表反轉(zhuǎn)
本文實例為大家分享了python實現(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: ?# 若鏈表為空或者僅一個數(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é)點2,先將節(jié)點2 保存起來。
第二步:head.next = pre (初始pre==None)
將 pre 變量賦值給 head.next,即 此時節(jié)點1 指向了 None
第三步:pre = head
將 head 賦值給了 pre,即 pre 指向節(jié)點1,將節(jié)點1 設(shè)為“上一個節(jié)點”
第四步:head = next
將 next 賦值給 head,即 head 指向了節(jié)點2,此時節(jié)點2 設(shè)為“頭節(jié)點”
第一次循環(huán)完畢,進入第二次循環(huán),如下圖:
第一步:next = head.next
將 head.next 賦值給 next 變量,即 next 指向了節(jié)點3,先將節(jié)點3 保存起來。
第二步:head.next = pre (此時的pre已經(jīng)不為None)
將 pre 賦值給 head.next,pre 在上一次循環(huán)的時候指向了節(jié)點1,那么這一步的意義就是節(jié)點2 指向了 節(jié)點1,完成1和2節(jié)點的反轉(zhuǎn)。
第三步:pre = head
將 head 賦值給了 pre,即 pre 指向節(jié)點2,將節(jié)點2 設(shè)為“上一個節(jié)點”
第四步:head = next
將 next 賦值給 head,即 head 指向了節(jié)點3。此時節(jié)點3 設(shè)為“頭節(jié)點”
第二次循環(huán)完畢,以此類推!第三次第四次第五次循環(huán)。最后反轉(zhuǎn)成如下圖
若干注意點:
(1)幫助記憶圖:
(2)當(dāng)前頭節(jié)點的下一個節(jié)點一定要保存(比如:當(dāng)前頭節(jié)點為2,先將節(jié)點3 保存起來)
(3)實現(xiàn)反轉(zhuǎn)的key point: head.next = pre
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法
這篇文章主要為大家介紹了Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08零基礎(chǔ)寫python爬蟲之爬蟲框架Scrapy安裝配置
Scrapy是一個使用Python編寫的,輕量級的,簡單輕巧,并且使用起來非常的方便。使用Scrapy可以很方便的完成網(wǎng)上數(shù)據(jù)的采集工作,它為我們完成了大量的工作,而不需要自己費大力氣去開發(fā)。2014-11-11Django+Uwsgi+Nginx如何實現(xiàn)生產(chǎn)環(huán)境部署
這篇文章主要介紹了Django+Uwsgi+Nginx如何實現(xiàn)生產(chǎn)環(huán)境部署,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07keras分類模型中的輸入數(shù)據(jù)與標簽的維度實例
這篇文章主要介紹了keras分類模型中的輸入數(shù)據(jù)與標簽的維度實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07在pycharm中關(guān)掉ipython console/PyDev操作
這篇文章主要介紹了在pycharm中關(guān)掉ipython console/PyDev操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06