力扣 606. 根据二叉树创建字符串

题目

你需要采用前序遍历的方式,将一个二叉树转换成一个由括号和整数组成的字符串。

空节点则用一对空括号 “()” 表示。而且你需要省略所有不影响字符串与原始二叉树之间的一对一映射关系的空括号对。

示例 1

输入: 二叉树: [1,2,3,4]
1
/
2 3
/
4

输出: “1(2(4))(3)”

解释: 原本将是“1(2(4)())(3())”,
在你省略所有不必要的空括号对之后,
它将是“1(2(4))(3)”。

输入: 二叉树: [1,2,3,null,4]
1
/
2 3
\
4

输出: “1(2()(4))(3)”

解释: 和第一个示例相似,
除了我们不能省略第一个对括号来中断输入和输出之间的一对一映射关系。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/construct-string-from-binary-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

方法1:dfs

在这里插入图片描述

Java实现
class Solution {
    StringBuffer res = new StringBuffer();
    public String tree2str(TreeNode root) {
        if (root == null) return "";
        dfs(root);
        return res.toString();
    }

    public void dfs(TreeNode root) {
        if (root == null) return;
        res.append(root.val);
        if (root.left == null && root.right == null) return;

        res.append("(");
        dfs(root.left);
        res.append(")");

        if (root.right != null) {
            res.append("(");
            dfs(root.right);
            res.append(")");
        }

    }
}

力扣 606. 根据二叉树创建字符串_第1张图片

你可能感兴趣的:(力扣,java)