題目描述注:設煉表長度為n。語言:c++輸入乙個鍊錶,按鍊錶從尾到頭的順序返回乙個arraylist。
鍊錶結點資料結構規定如下:
* 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.方法二 鍊錶的逆序列印,首先肯定要遍歷鍊錶,可是輸出的順序卻是從尾到頭。也就是說,第乙個遍歷到的節...