【问题描述】
输入一个链表,按链表从尾到头的顺序返回一个ArrayList。
/**
* public class ListNode {
* int val;
* ListNode next = null;
*
* ListNode(int val) {
* this.val = val;
* }
* }
*
*/
【解答思路】
1.ArrayList遍历接收,翻转
import java.util.ArrayList;
import java.util.Collections;
public class Solution {public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {ArrayList<Integer> list = new ArrayList<Integer>();while(listNode != null){list.add(listNode.val);listNode = listNode.next;}Collections.reverse(list);//使用Collections的reverse方法,直接将list反转return list;}
}
2.想到栈的特性先入后出,完成逆序
import java.util.ArrayList;
import java.util.Stack;
public class Solution {public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {Stack<Integer> stack=new Stack<Integer>();while(listNode!=null){stack.push(listNode.val);listNode=listNode.next; }ArrayList<Integer> list=new ArrayList<Integer>();while(!stack.isEmpty()){list.add(stack.pop());}return list;}
}
3.递归实现 (递归的本质还是使用了堆栈结构)
import java.util.ArrayList;
import java.util.Stack;
public class Solution {public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {ArrayList<Integer> list=new ArrayList<Integer>();ListNode pNode=listNode;if(pNode!=null){if(pNode.next!=null){list=printListFromTailToHead(pNode.next);}list.add(pNode.val);}return list;}
}
【总结】
1.链表基础知识
- 新建
LinkedList<String> lList = new LinkedList<String>();
- 遍历
while(listNode!=null){listNode=listNode.next; }
2.堆栈基本操作
- 新建
Stack<Integer> stack=new Stack<Integer>();
- 出栈
while(!stack.isEmpty())
{x = stack.pop();
}
- 入栈
stack.push(val);