題目描述
輸入一個鏈表,從尾到頭打印鏈表每個節點的值。
測試用例:
{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