从尾到头打印链表
输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。
/**
* public class ListNode {
* int val;
* ListNode next = null;
*
* ListNode(int val) {
* this.val = val;
* }
* }
*
*/
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> list = new ArrayList<Integer>();
ArrayList<Integer> list2 = new ArrayList<Integer>();
while(listNode != null) {//先把链表的数据从头到尾储存在list中
list.add(listNode.val);
listNode = listNode.next;
}
for(int i = list.size()-1; i >= 0; i--) {//把list反转到list2中
list2.add(list.get(i));
}
return list2;
}
解法二:
解题思路:优化做法,利用递归的特性,运行到中途调用递归直到出口再一个个返回来计算,这样就可以完美地从链表的末尾开始取到数据。直接判断当前结点是否为null,不为空就一直调用下一个结点,直到最后一个结点就开始添加数据到arrayList中,从链表的尾端一个一个地添加到arrayList中,最后结果就是返回这个arrayList即可。
import java.util.ArrayList;
public class Solution {
ArrayList<Integer> arrayList=new ArrayList<Integer>();
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
if(listNode != null) {
this.printListFromTailToHead(listNode.next);
arrayList.add(listNode.val);
}
return arrayList;
}
}