Description:
输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。
Notes:
- 时间限制:1秒
- 空间限制:32768K
解题思路:首先,将链表中的节点指依次存储在列表中;最后,将首尾两个元素两两交换得到逆序的链表节点值;
Java
/**
* 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> result = new ArrayList<>();
while (listNode != null) {
result.add(listNode.val);
listNode = listNode.next;
}
int st = 0;
int ed = result.size() - 1;
while (st < ed) {
int temp = result.get(st);
result.set(st, result.get(ed));
result.set(ed, temp);
st++;
ed--;
}
return result;
}
}