[leetcode]114. Flatten Binary Tree to Linked List由二叉树构建链表

/*
    先序遍历构建链表,重新构建树
     */
    LinkedList<Integer> list = new LinkedList<>();
    public void flatten(TreeNode root) {
        preOrder(root);
        TreeNode res = root;
        list.poll();
        while (!list.isEmpty())
        {
            res.right = new TreeNode(list.poll());
            res.left = null;
            res = res.right;
        }
    }
    public void preOrder(TreeNode root)
    {
        if (root==null)
            return;
        list.offer(root.val);
        preOrder(root.left);
        preOrder(root.right);
    }

 

posted @ 2018-01-24 12:22  stAr_1  阅读(136)  评论(0编辑  收藏  举报