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

2021-10-23 09:01:57 字數 769 閱讀 2500

題目描述

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

注:設煉表長度為n。語言:c++

鍊錶結點資料結構規定如下:

*  struct listnode 

* };

解法1:正向遍歷,借助反向迭代器實現序列逆置(c++特性)。

vectorprintlistfromtailtohead(listnode* head) 

return vector(array.rbegin(), array.rend());

}

時間複雜度:o(n),空間複雜度:o(1)

解法2:借助棧先進後出的特性,將鍊錶結點先入棧後出棧,再壓入序列中。

vectorprintlistfromtailtohead(listnode* head) 

p = head;

vectorarray;

while(p != null)

return array;

}

時間複雜度:o(n),空間複雜度:o(n)

解法3:遞迴

vectorarray;

vectorprintlistfromtailtohead(listnode* head)

return array;

}

時間複雜度:o(n),空間複雜度:o(n)

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

輸入乙個鍊錶,按煉錶值從尾到頭的順序返回乙個arraylist。1.從頭開始,每經過乙個節點就把它的值儲存下來,最後反轉 coding utf 8 class listnode def init self,x self.val x self.next none class solution 返回從尾...

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

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

劍指offer 從尾到頭列印列表

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