LintCode 69. 二叉树的层次遍历

这题简单是典型的bfs题,注意递归最后将本层节点的集合作为下一层的集合

import org.junit.Test;
import tree.TreeNode;

import java.util.LinkedList;
import java.util.List;

public class LevelOrder {
    /**
     * @param root: A Tree
     * @return: Level order a list of lists of integer
     * <p>
     * 69. 二叉树的层次遍历
     * 给出一棵二叉树,返回其节点值的层次遍历(逐层从左往右访问)
     * <p>
     * 样例
     * 给一棵二叉树 {3,9,20,#,#,15,7} :
     * <p>
     * 3
     * / \
     * 9  20
     * /  \
     * 15   7
     * 返回他的分层遍历结果:
     * <p>
     * [
     * [3],
     * [9,20],
     * [15,7]
     * ]
     * 挑战
     * 挑战1:只使用一个队列去实现它
     * <p>
     * 挑战2:用DFS算法来做
     */
    public List<List<Integer>> levelOrder(TreeNode root) {
        // write your code here
        List<List<Integer>> results = new LinkedList<>();
        List<Integer> level = new LinkedList<>();
        LinkedList<TreeNode> currentLevelNode = new LinkedList<>();
        LinkedList<TreeNode> nextLevelNode = new LinkedList<>();
        if (root == null) {
            return results;
        }

        currentLevelNode.add(root);
        bfs(results, level, currentLevelNode, nextLevelNode);
        return results;
    }

    private void bfs(List<List<Integer>> results, List<Integer> level,
                     LinkedList<TreeNode> currentLevelNode, LinkedList<TreeNode> nextLevelNode) {
        if (currentLevelNode.size() == 0) {
            return;
        }
        while (currentLevelNode.size() != 0) {
            TreeNode treeNode = currentLevelNode.poll();
//            System.out.println(treeNode.val);
            level.add(treeNode.val);
            if (treeNode.left != null) {
                nextLevelNode.add(treeNode.left);
            }
            if (treeNode.right != null) {
                nextLevelNode.add((treeNode.right));
            }
        }
        results.add(new LinkedList<>(level));
        level.clear();
        bfs(results, level, nextLevelNode, currentLevelNode);
    }

    @Test
    public void testLevelOrder() {
        TreeNode treeNode1 = new TreeNode(1);
        TreeNode treeNode2 = new TreeNode(2);
        TreeNode treeNode3 = new TreeNode(3);

        treeNode1.left = treeNode2;
        treeNode1.right = treeNode3;

        List<List<Integer>> results = levelOrder(treeNode1);
        for (int i = 0; i < results.size(); i++) {
            System.out.println(results.get(i).toString());
        }

    }
}
posted @ 2018-08-22 22:45  wei1  阅读(104)  评论(0编辑  收藏  举报