原题链接:606. 根据二叉树创建字符串
solution:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
private:
string res; //定义返回值
public:
void dfs(TreeNode *root)
{
if(!root) return; //如果该节点不存在直接返回
res.append(to_string(root->val)); //否则加上当前节点值
if(root->left || root->right){ //如果左节点或右节点有一个存在则需要加上括号
res.append("(");
dfs(root->left);
res.append(")");
}
if(root->right){
res.append("(");
dfs(root->right);
res.append(")");
}
string tree2str(TreeNode* root) {
dfs(root);
return res;
}
};