每天一道算法題——從尾到頭輸出鏈表

題目描述
輸入一個鏈表,從尾到頭打印鏈表每個節點的值。
測試用例:
{67,0,24,58}

對應輸出應該爲:

[58,24,0,67]

1.使用遞歸,但是此方法不適用於長鏈表。

import java.util.ArrayList;
public class Test1 {
    ArrayList<Integer> arrayList=new ArrayList<Integer>();
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {

        if (listNode!=null) {
            this.printListFromTailToHead(listNode.next);//此處遞歸至最後一值。
            arrayList.add(listNode.val);//將各遞歸結果依次傳入ArrayList
        }
        return arrayList;
    }
}

class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}

2.利用棧的“後進先出”的特點來實現從尾部打印:

import java.util.ArrayList;
import java.util.Stack;
public class Test1 {
    ArrayList<Integer> arrayList=new ArrayList<Integer>();
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        Stack<Integer> stack = new Stack<Integer>();
        while  (listNode!=null) {
            stack.push(listNode.val);
            listNode = listNode.next;
        }
        while(!stack.isEmpty()){
            arrayList.add(stack.pop());//取出棧頭的值,即尾部。加入ArrayList。
        }
        return arrayList;
    }
}

class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}

測試結果:
第一種:22ms
第二種:18ms

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章