从尾到头打印链表
定义链表:
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}
思路:借助栈先进后出的结构思想,初始化构建一个新的链表,首先判断原链表是否为空,若为空直接返回新链表头结点;将原链表的元素依次压栈;再将栈中元素依次出栈放到新链表中,新链表的元素顺序即为原链表的反转顺序;返回新链表头结点。
import java.util.ArrayList;
import java.util.Stack;
public class Solution {
public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> arrayList=new ArrayList<Integer>();
if(listNode==null)
return arrayList;
Stack<Integer> stack=new Stack<Integer>();
while(listNode!=null){
stack.push(listNode.val);
listNode=listNode.next;
}
while(!stack.isEmpty()){
arrayList.add(stack.pop());
}
return arrayList;
}
}