劍指offer第三題 從尾到頭列印鍊錶

2021-08-31 16:32:50 字數 935 閱讀 2908

輸入乙個鍊錶,按煉錶值從尾到頭的順序返回乙個arraylist。

1. 從頭開始,每經過乙個節點就把它的值儲存下來,最後反轉

# -*- coding:utf-8 -*-

# class listnode:

# def __init__(self, x):

# self.val = x

# self.next = none

class solution:

# 返回從尾部到頭部的列表值序列,例如[1,2,3]

def printlistfromtailtohead(self, listnode):

# write code here

res =

while listnode:

listnode = listnode.next

return res[::-1]

2. 遍歷鍊錶,把鍊錶值插入到0位置

# -*- coding:utf-8 -*-

# class listnode:

# def __init__(self, x):

# self.val = x

# self.next = none

class solution:

# 返回從尾部到頭部的列表值序列,例如[1,2,3]

def printlistfromtailtohead(self, listnode):

# write code here

res =

while listnode:

res.insert(0, listnode.val)

listnode = listnode.next

return res

劍指offer第三題 從尾到頭列印鍊錶

鍊錶知識點 1.為什麼不能將cur指向當前元素 為什麼head初始化時是個空指標 如果這樣做,插入只能在cur之後,當前節點的前驅結點的next指標將無法更新,不能在cur之前,很難實現在鍊錶第乙個元素之前插入的問題,2.可利用空間表 過載new與delete操作,使得記憶體的分配更加方便。刪除的節...

劍指Offer第三題 從尾到頭列印鍊錶

題目描述 輸入乙個鍊錶,按鍊錶從尾到頭的順序返回乙個arraylist。注 設煉表長度為n。語言 c 鍊錶結點資料結構規定如下 struct listnode 解法1 正向遍歷,借助反向迭代器實現序列逆置 c 特性 vectorprintlistfromtailtohead listnode hea...

劍指offer 從尾到頭列印列表

1.方法一 看到這道題的時候,我的最初想法是鍊錶翻轉,在輸出。在原書中作者認為這不是最好的解決辦法,因為這樣會改變鍊錶的原來的結構,如果在面試中遇到類似的問題,應該主動詢問面試官這樣的方發是否可行。1.方法二 鍊錶的逆序列印,首先肯定要遍歷鍊錶,可是輸出的順序卻是從尾到頭。也就是說,第乙個遍歷到的節...