输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。
算法流程:辅助栈法:
入栈: 遍历链表,将各节点值 push 入栈。(Python 使用 append() 方法,Java借助 linkedList 的addLast()方法)。
出栈: 将各节点值 pop 出栈,存储于数组并返回。(Python 直接返回 stack 的倒序列表,Java 新建一个数组,通过 popLast() 方法将各元素存入数组,实现倒序输出)。
class Solution {
public int[] reversePrint(ListNode head) {
linkedList stack = new linkedList();
while(head != null) {
stack.addLast(head.val);
head = head.next;
}
int[] res = new int[stack.size()];
for(int i = 0; i < res.length; i++)
res[i] = stack.removeLast();
return res;
}
}



