欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python版單鏈表反轉(zhuǎn)

 更新時(shí)間:2022年05月05日 09:50:30   作者:xiaoming_tju  
這篇文章主要為大家詳細(xì)介紹了python版單鏈表反轉(zhuǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法

    Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法

    這篇文章主要為大家介紹了Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Python中import的用法陷阱解決盤點(diǎn)小結(jié)

    Python中import的用法陷阱解決盤點(diǎn)小結(jié)

    這篇文章主要為大家介紹了Python中import的用法陷阱解決盤點(diǎn)小結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 零基礎(chǔ)寫python爬蟲之爬蟲框架Scrapy安裝配置

    零基礎(chǔ)寫python爬蟲之爬蟲框架Scrapy安裝配置

    Scrapy是一個(gè)使用Python編寫的,輕量級(jí)的,簡單輕巧,并且使用起來非常的方便。使用Scrapy可以很方便的完成網(wǎng)上數(shù)據(jù)的采集工作,它為我們完成了大量的工作,而不需要自己費(fèi)大力氣去開發(fā)。
    2014-11-11
  • Django+Uwsgi+Nginx如何實(shí)現(xiàn)生產(chǎn)環(huán)境部署

    Django+Uwsgi+Nginx如何實(shí)現(xiàn)生產(chǎn)環(huán)境部署

    這篇文章主要介紹了Django+Uwsgi+Nginx如何實(shí)現(xiàn)生產(chǎn)環(huán)境部署,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • python輪詢機(jī)制控制led實(shí)例

    python輪詢機(jī)制控制led實(shí)例

    這篇文章主要介紹了python輪詢機(jī)制控制led實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • 在python中利用opencv簡單做圖片比對(duì)的方法

    在python中利用opencv簡單做圖片比對(duì)的方法

    今天小編就為大家分享一篇在python中利用opencv簡單做圖片比對(duì)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python基于xlrd模塊操作Excel的方法示例

    Python基于xlrd模塊操作Excel的方法示例

    這篇文章主要介紹了Python基于xlrd模塊操作Excel的方法,結(jié)合實(shí)例形式分析了xlrd模塊的安裝及Python使用xlrd模塊模塊進(jìn)行Excel的讀寫相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06
  • keras分類模型中的輸入數(shù)據(jù)與標(biāo)簽的維度實(shí)例

    keras分類模型中的輸入數(shù)據(jù)與標(biāo)簽的維度實(shí)例

    這篇文章主要介紹了keras分類模型中的輸入數(shù)據(jù)與標(biāo)簽的維度實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • python的語句結(jié)構(gòu)你真的了解嗎

    python的語句結(jié)構(gòu)你真的了解嗎

    這篇文章主要為大家詳細(xì)介紹了python的語句結(jié)構(gòu),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • 在pycharm中關(guān)掉ipython console/PyDev操作

    在pycharm中關(guān)掉ipython console/PyDev操作

    這篇文章主要介紹了在pycharm中關(guān)掉ipython console/PyDev操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06

最新評(píng)論