使用递归的方式,将链表反转。具体实现如下:
class ListNode: def init(self, x): self.val = x self.next = None
class Solution: def reverseList(self, head: ListNode) -> ListNode: if not head or not head.next: return head p = self.reverseList(head.next) head.next.next = head head.next = None return p
n1 = ListNode(1) n2 = ListNode(2) n3 = ListNode(3) n4 = ListNode(4) n1.next = n2 n2.next = n3 n3.next = n4 s = Solution() p = s.reverseList(n1) while p: print(p.val) p = p.next
输出结果为: 4 3 2 1
这里我们使用了递归的方式,截止条件是当前节点为空或者下一个节点为空。递归结束后,将前一个节点的指针指向本节点即可完成反转。最后返回新的链表的头节点。