首页 > 其他 > 详细

expression tree to string

时间:2014-11-23 17:15:01      阅读:195      评论:0      收藏:0      [点我收藏+]

+
/ \
1 *
/ \
5 6

这样的。要返回1+(5*6)

struct TreeNode
{
    TreeNode * left, *right;
    string val;
    TreeNode(string i) :val(i), left(NULL), right(NULL){}
};
 
bool IsOperator(const string & c)
{
    if (c.length() > 1 || (c[0] >= 0 && c[0] <= 9))
    {
        return false;
    }
    return true;
}
 
string ExpressionTreeToString(TreeNode * node)
{
    if (node == NULL)
        return "";
    string ret = node->val;
    if (IsOperator(node->val))
    {
        if (node->left)
        {
            if (IsOperator(node->left->val))
            {
                ret.insert(0, "(" + ExpressionTreeToString(node->left) + ")");
            }
            else
            {
                ret.insert(0, ExpressionTreeToString(node->left));
            }
        }
        if (node->right){
            if (IsOperator(node->right->val))
            {
                ret += "(" + ExpressionTreeToString(node->right) + ")";
            }
            else
            {
                ret += ExpressionTreeToString(node->right);
            }
        }
    }
    return ret;
}

 

expression tree to string

原文:http://www.cnblogs.com/jobfindingnotes/p/4116629.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!