题目描述
输入一个链表,按链表从尾到头的顺序返回一个ArrayList。
解题思路
1.建一个列表模拟栈,将链表里的元素全部遍历到栈中,从栈顶一个一个弹出。
/**
* public class ListNode {
* int val;
* ListNode next = null;
*
* ListNode(int val) {
* this.val = val;
* }
* }
*
*/
import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> list = new ArrayList<Integer>(); //模拟栈
ArrayList<Integer> put = new ArrayList<Integer>(); //输出结果
while(listNode!= null)
{
list.add(listNode.val);
listNode = listNode.next;
}
for(int i = list.size()-1;i>=0;i--) //从0开始所以要-1
put.add(list.get(i));
return put;
}
}
2.貌似还可以用递归做。