华为机试:二叉树中序遍历

题目来源

题目描述

在这里插入图片描述

题目解析

思路

class Solution{
    struct TreeNode{
        char ch;
        TreeNode *left;
        TreeNode *right;
    public:
        TreeNode(char ch) : ch(ch){
        }
    };



    std::deque<TreeNode *> deque;
    bool isNode(char ch){
        return (ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z');
    };

    // 返回下一个要看的位置
    int process(std::string &str, int start){
        int i = start;
        while (i < str.size() && str[i] != '}') {
            if(isNode(str[i])){  // {a}, a, a{}, {a.}
                deque.push_back(new TreeNode(str[i]));  // {f}
                if(i + 1 < str.size() && str[i + 1] == '}'){  
                    deque.push_back(NULL);
                }

                i = i + 1;
            }else if(str[i] == '{'){   // {f}
                i = process(str, i + 1);
            }else {
                if(str[i - 1] == '{' && str[i + 1] == '}'){
                    deque.push_back(NULL);
                    deque.push_back(NULL);
                    i = i + 1;
                }else if(str[i - 1] == '{'){  // {.a}
                    deque.push_back(NULL);
                    deque.push_back(new TreeNode(str[i + 1]));
                    i = i + 2;
                }else if(str[i + 1] == '}'){  // {a.}
                    deque.push_back(NULL);
                    i = i + 1;
                }else{  // d,e
                    deque.push_back(new TreeNode(str[i + 1]));
                    i = i + 2;
                }
            }
        }

        if(deque.size() >= 3){
            auto right = deque.back(); deque.pop_back();
            auto left = deque.back(); deque.pop_back();
            deque.back()->right = right;
            deque.back()->left = left;
        }

        return i + 1;
    }
public:
    TreeNode *genereTree(std::string &str){
        if(str.empty()){
            return NULL;
        }


        process(str, 0);
        return deque.front();  //至少会含有一个
    }

    void inorderTraval(TreeNode *root,  std::string &ans){
        if(root == nullptr){
            return ;
        }

        inorderTraval(root->left, ans);
        ans.push_back(root->ch);
        inorderTraval(root->right, ans);
    }
};
int main(){
    std::string line = "a{b{d,e{g,h{,I}}},c{f}}";
    while (getline(cin, line)){
        Solution a;
        auto root = a.genereTree(line);
        std::string order;
        a.inorderTraval(root, order);
        std::cout << order << "\n";
    }
    return 0;
}

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值