从尾到头打印链表
package com;
import java.util.ArrayList;
class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}
public class Solution {
//递归函数
public static void recursion(ListNode head, ArrayList<Integer> res) {
if (head != null) {
//先往链表深处遍历
recursion(head.next, res);
//再填充到数组就是逆序
res.add(head.val);
}
}
public static ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
ArrayList<Integer> res = new ArrayList<Integer>();
//递归函数解决
recursion(listNode, res);
return res;
}
public static void main(String[] args) {
ListNode listNode1 = new ListNode(1);
ListNode listNode2 = new ListNode(2);
ListNode listNode3 = new ListNode(3);
ListNode listNode4 = new ListNode(4);
listNode1.next = listNode2;
listNode2.next = listNode3;
listNode3.next = listNode4;
ArrayList<Integer> integers = printListFromTailToHead(listNode1);
System.out.println(integers);
}
}
问题:为什么在遇到终止条件head==null之后,仍弄够返回recursion中的res.add(head.var)处执行,且还能循环执行四次。