思路:
- 从头遍历 :如果知道java ArrayList的 add()方法其实是插入方法add(0,val),在0处插入,后面都往后移动一格,
理论上可以一次遍历输出,这个方法调用arraycopy方法把后面的元素往后移动一个位置,native方法,效率应该是很高了。 - 递归(栈):这个思路和前序遍历二叉树一致,递归的缺点在于占内存。
- 反转链表:利用三个指针反转这个链表,然后遍历。
代码
从头遍历
import java.util.ArrayList;
public class Solution {
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> arr=new ArrayList<>();
while(listNode!=null){
arr.add(0,listNode.val);
listNode=listNode.next;
}
return arr;
}
} 
京公网安备 11010502036488号