剑指 Offer 06. 从尾到头打印链表
题目:
输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。
示例 1:
输入:head = [1,3,2]
输出:[2,3,1]
限制:
0 <= 链表长度 <= 10000
解题:
法一:反转数组
遍历整个链表,将数据存在数组里,并反转数组
class Solution:
def reversePrint(self, head: ListNode) -> List[int]:
lst = []
while head:
lst.append(head.val)
head = head.next
return lst[::-1]
法二:递归
class Solution:
def reversePrint(self, head: ListNode) -> List[int]:
if not head:
return []
if not head.next:
return [head.val]
return self.reversePrint(head.next)+[head.val]