輸入乙個鍊錶,按煉錶值從尾到頭的順序返回乙個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.方法二 鍊錶的逆序列印,首先肯定要遍歷鍊錶,可是輸出的順序卻是從尾到頭。也就是說,第乙個遍歷到的節...