107. 二叉树的层次遍历 II

博客提及 LeetCode 上的二叉树的层次遍历 II 问题,链接为 https://leetcode-cn.com/problems/binary-tree-level-order-traversal-ii/description/ ,涉及数据结构与算法相关知识。

107. 二叉树的层次遍历 II

https://leetcode-cn.com/problems/binary-tree-level-order-traversal-ii/description/

package com.test;

import java.util.ArrayList;
import java.util.List;

/**
 * @Author stono
 * @Date 2018/8/27 上午10:40
 */
public class Lesson107 {
    public static void main(String[] args) {
        TreeNode t1 = new TreeNode(1);
        TreeNode t2L = new TreeNode(2);
        TreeNode t2R = new TreeNode(2);
        TreeNode t3_1 = new TreeNode(3);
        TreeNode t3_2 = new TreeNode(4);
        TreeNode t3_3 = new TreeNode(4);
        TreeNode t3_4 = new TreeNode(3);
        t1.left = t2L;
        t1.right = t2R;
        t2L.left = t3_1;
        t2L.right = t3_2;
        t2R.left = t3_3;
        t2R.right = t3_4;
        List<List<Integer>> lists = levelOrderBottom(t1);
        System.out.println(lists);
    }
    public static List<List<Integer>> levelOrderBottom(TreeNode root) {
        List<List<Integer>> res = new ArrayList<>();
        if (root == null) {
            return res;
        }
        List<Integer> list = new ArrayList<>(8);
        list.add(root.val);
        TreeNode leftNode = root.left;
        TreeNode rightNode = root.right;
        List<TreeNode> nodes = new ArrayList<>();
        nodes.add(leftNode);
        nodes.add(rightNode);
        // 进行递归累加
        levelOrderBottom(res, nodes);
        res.add(list);
        return res;
    }

    private static void levelOrderBottom(List<List<Integer>> res, List<TreeNode> nodes) {
        List<Integer> list = new ArrayList<>(8);
        List<TreeNode> nodes2 = new ArrayList<>();
        for (TreeNode node : nodes) {
            if (node != null) {
                list.add(node.val);
                nodes2.add(node.left);
                nodes2.add(node.right);
            }
        }
        // 如果遍历结果中包含了多个数字
        if (list.size() > 0) {
            levelOrderBottom(res, nodes2);
            res.add(list);
        }
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值