反转链表 python 递归_LeetCode 206.反转链表(Python3)
生活随笔
收集整理的這篇文章主要介紹了
反转链表 python 递归_LeetCode 206.反转链表(Python3)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
題目:
反轉(zhuǎn)一個單鏈表。
示例:
輸入: 1->2->3->4->5->NULL
輸出: 5->4->3->2->1->NULL
進階:
你可以迭代或遞歸地反轉(zhuǎn)鏈表。你能否用兩種方法解決這道題?
解答:
方法一:原地反轉(zhuǎn)。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def reverseList(self, head: 'ListNode') -> 'ListNode':
# cur當前節(jié)點
# pre為當前節(jié)點的上一個節(jié)點,反轉(zhuǎn)后的下一個節(jié)點
# nex為當前節(jié)點的下一個節(jié)點,反轉(zhuǎn)后的上一個節(jié)點
cur = head
pre = None
while cur:
# 節(jié)點原地反轉(zhuǎn)
nex = cur.next
cur.next = pre
pre = cur
# 進入下一個要反轉(zhuǎn)的節(jié)點
cur = nex
return pre
總結(jié)
以上是生活随笔為你收集整理的反转链表 python 递归_LeetCode 206.反转链表(Python3)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: r语言echarts画箱线图_R语言之数
- 下一篇: c语言exit_看了这几个C语言例子,你