中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么實現單鏈表中元素的反轉

發布時間:2022-05-05 10:25:04 來源:億速云 閱讀:135 作者:iii 欄目:開發技術

這篇文章主要介紹了Python怎么實現單鏈表中元素的反轉的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Python怎么實現單鏈表中元素的反轉文章都會有所收獲,下面我們一起來看看吧。

給定一個單鏈表,將其反轉。其實很容易想到,只需要修改每個結點的指針指向:即令后一個結點指向前一個結點,并且將表頭指針指向最后一個結點即可。

Python怎么實現單鏈表中元素的反轉

這個過程可以用循環實現,也可以用遞歸來實現。

1、用循環來實現:

class LNode:
    def __init__(self, elem):
        self.elem = elem
        self.pnext = None
 
def reverse(head):
    if head is None or head.pnext is None: #如果輸入的鏈表是空或者只有一個結點,直接返回當前結點
        return head
    pre = None #用來指向上一個結點
    cur = newhead = head #cur是當前的結點。newhead指向當前新的頭結點
    while cur:
        newhead = cur
        temp = cur.pnext
        cur.pnext = pre #將當前的結點的指針指向前一個結點
        pre = cur
        cur = temp
    return newhead
 
if __name__=="__main__":
    head = LNode(1)
    p1 = LNode(2)
    p2 = LNode(3)
    head.pnext = p1
    p1.pnext = p2
    p = reverse(head)
    while p:
        print(p.elem)
        p = p.pnext

2、用遞歸來實現:

class LNode:
    def __init__(self, elem):
        self.elem = elem
        self.pnext = None
 
def reverse(head):
    if not head or not head.pnext:
        return head
    else:
        newhead = reverse(head.pnext)
        head.pnext.pnext = head #令下一個結點的指針指向當前結點
        head.pnext = None #斷開當前結點與下一個結點之間的指針指向聯系,令其指向空
        return newhead
 
 
if __name__=="__main__":
    head = LNode(1)
    p1 = LNode(2)
    p2 = LNode(3)
    head.pnext = p1
    p1.pnext = p2
    p = reverse(head)
    while p:
        print(p.elem)
        p = p.pnext

以下是圖解遞歸的詳細過程:

Python怎么實現單鏈表中元素的反轉

關于“Python怎么實現單鏈表中元素的反轉”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Python怎么實現單鏈表中元素的反轉”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

石林| 邢台市| 景宁| 娱乐| 邻水| 莫力| 澜沧| 卓尼县| 丹棱县| 山阴县| 营口市| 辽宁省| 东乡族自治县| 阜平县| 伊宁市| 大荔县| 洞头县| 邯郸县| 仁怀市| 大悟县| 综艺| 治县。| 成安县| 休宁县| 白城市| 西乌珠穆沁旗| 兰西县| 丹巴县| 赤城县| 宁强县| 祁门县| 清丰县| 石城县| 格尔木市| 封开县| 镶黄旗| 永修县| 綦江县| 定边县| 永胜县| 新干县|