剑指 Offer 06. 从尾到头打印链表

剑指 Offer 06. 从尾到头打印链表

难度:简单

输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。

示例 :
输入:head = [1,3,2]
输出:[2,3,1]
限制:

0 <= 链表长度 <= 10000

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/cong-wei-dao-tou-da-yin-lian-biao-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

先遍历链表,将链表中的元素依次添加到一个数组之中。遍历结束之后,数组中的元素是从头到尾的,需要进行调转。

python中有现成调转数组的方法,如果是c语言的话,需要遍历数组的前一半,与数组的后一半交换位置。

解题源码:
class Solution:
    def reversePrint(self, head: ListNode) -> List[int]:
        l = []
        while head:
            l.append(head.val)
            head = head.next
        l.reverse()
        return l
posted @ 2022-02-12 15:33  红雨520  阅读(29)  评论(0)    收藏  举报