你需要采用前序遍历的方式,将一个二叉树转换成一个由括号和整数组成的字符串。
空节点则用一对空括号 "()" 表示。而且你需要省略所有不影响字符串与原始二叉树之间的一对一映射关系的空括号对。
示例 1:
输入: 二叉树: [1,2,3,4]
1
/ \
2 3
/
4
输出: "1(2(4))(3)"
解释: 原本将是“1(2(4)())(3())”,
在你省略所有不必要的空括号对之后,
它将是“1(2(4))(3)”。
示例 2:
输入: 二叉树: [1,2,3,null,4]
1
/ \
2 3
\
4
输出: "1(2()(4))(3)"
解释: 和第一个示例相似,
除了我们不能省略第一个对括号来中断输入和输出之间的一对一映射关系。
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
string tree2str(TreeNode* t) {
string str = "";
if(t == NULL)
return str;
bianli(t, str);
str.erase(str.end() - 1, str.end());
return str;
}
void bianli(TreeNode* t, string &str)
{
if(t == NULL)
return ;
if(str.length() != 0)
str += "(";
str += to_string(t->val);
//此处为当左子树为null 右子树不为null
if(t->right != NULL && t->left == NULL)
str += "()";
bianli(t->left, str);
bianli(t->right, str);
str += ")";
}
};
本文介绍了一种算法,该算法能将二叉树结构转换为由括号和整数组成的字符串,通过前序遍历实现。文章详细解释了如何在转换过程中省略不影响一对一映射关系的空括号,提供了两个示例帮助理解。
374

被折叠的 条评论
为什么被折叠?



