Java ListNode 递归 遍历

ListNode 基本结构

 

class ListNode {
    int val;
    ListNode next;

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

递归遍历到List

    private void pbulic(ArrayList<Integer> list,ListNode listNode) {
        if (listNode == null) {
            return;
        }
//     list.add(listNode.val);//从头开始遍历 pbulic(list,listNode.next); list.add(listNode.val);//从尾部开始遍历 }

从头遍历 到List

ArrayList<Integer> list = new ArrayList<Integer>();
        ArrayList<Integer> listInv = new ArrayList<Integer>();

        ListNode now = listNode;
        while (now != null) {
            list.add(now.val);
            now = now.next;
        }

        for (int i = list.size() - 1; i > -1; i--) {
            listInv.add(list.get(i));
        }
        log.info(listInv);
        now = listNode;
        while (now != null) {
            log.info(now.val);
            now = now.next;
        }
        return listInv;

 

posted @ 2022-02-12 10:28  山风在  阅读(851)  评论(0)    收藏  举报