剑指offer第三题 从尾到头打印链表

Posted haq123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer第三题 从尾到头打印链表相关的知识,希望对你有一定的参考价值。

输入一个链表,按链表从尾到头的顺序返回一个ArrayList。

 

解题思路:先入栈相当于链表逆序再出栈实现链表从尾到头的顺序输出。

 1 /**
 2 *    public class ListNode {
 3 *        int val;
 4 *        ListNode next = null;
 5 *
 6 *        ListNode(int val) {
 7 *            this.val = val;
 8 *        }
 9 *    }
10 *
11 */
12 import java.util.*;
13 public class Solution {
14     public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
15         if(listNode == null){
16             return new ArrayList();
17         }else{
18             ArrayList<Integer> arr = new ArrayList<Integer>();
19             Stack<Integer> ss = new Stack<Integer>();
20             while(listNode!=null){
21                 ss.push(Integer.valueOf(listNode.val));
22                 listNode = listNode.next;
23             }
24             while(!ss.empty()){
25                 arr.add(ss.pop());
26             }
27             return arr;
28         }
29     }
30 }

注意:new ArrayList()与 NULL 不相等

  ArrayList源码中默认初始的容量为10
  private static final int DEFAULT_CAPACITY = 10;

ps:源码很重要。。。还是要加油!!!

以上是关于剑指offer第三题 从尾到头打印链表的主要内容,如果未能解决你的问题,请参考以下文章

剑指 Offer 06. 从尾到头打印链表

《剑指Offer—— 06. 从尾到头打印链表》代码

《剑指offer》— JavaScript从尾到头打印链表

剑指offer从尾到头打印链表python

剑指offer从尾到头打印链表

剑指Offer-从尾到头打印链表