基于Python實現(xiàn)2種反轉(zhuǎn)鏈表方法代碼實例
題目:
反轉(zhuǎn)一個單鏈表。
示例:
輸入: 1->2->3->4->5->NULL
輸出: 5->4->3->2->1->NULL
進階:
你可以迭代或遞歸地反轉(zhuǎn)鏈表。你能否用兩種方法解決這道題?
思路:
主要需要注意反轉(zhuǎn)過程中不要丟了節(jié)點。可以使用兩個指針,也可以使用三個指針。


Python解法一:
class Solution: def reverseList(self, head): cur, prev = head, None while cur: temp = cur.next cur.next = prev prev = cur cur = temp return prev
Python解法二:
class Solution: def reverseList(self, head): if head == None or head.next == None: return head prev = None cur = head post = head.next while post: cur.next = prev prev = cur cur = post post = post.next cur.next = prev return cur
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP基礎(chǔ)知識VBScript基本元素講解2. ASP.NET MVC使用jQuery ui的progressbar實現(xiàn)進度條3. Python 合并拼接字符串的方法4. Linux刪除系統(tǒng)自帶版本Python過程詳解5. Python3 json模塊之編碼解碼方法講解6. python 使用事件對象asyncio.Event來同步協(xié)程的操作7. Python sublime安裝及配置過程詳解8. Python 利用Entrez庫篩選下載PubMed文獻摘要的示例9. Python 制作查詢商品歷史價格的小工具10. Python插件機制實現(xiàn)詳解

網(wǎng)公網(wǎng)安備