首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >POJ 2255 Tree Recovery(已知前序&中序,求后序)

POJ 2255 Tree Recovery(已知前序&中序,求后序)

作者头像
Michael阿明
发布2021-02-20 10:42:38
发布2021-02-20 10:42:38
3260
举报

1. 题目链接:http://poj.org/problem?id=2255

2. 题目大意:

给定二叉树的前序和中序序列,输出其后序序列

3. 思考过程:

4. AC代码

代码语言:javascript
复制
/**
 * @description: 给出前序和中序二叉树节点序列,求后序二叉树节点输出序列
 * @author: michael ming
 * @date: 2019/5/21 18:49
 * @modified by: 
 */
#include <iostream>
#include <string>
using namespace std;
void postOrder(string &pre, int pre_start, int pre_end, string &in, int in_start, int in_end)
{
    char root = pre[pre_start]; //前序的根节点
    int pos = in.find(root);    //在中序里找到root
    int L_len = pos - in_start, R_len = in_end - pos;   //计算左右子树长度
    if(L_len >= 1)
        postOrder(pre, pre_start+1, pre_start+L_len, in, in_start, pos-1);  //对左子树递归调用
    if(R_len >= 1)
        postOrder(pre, pre_start+L_len+1, pre_end, in, pos+1, pos+R_len);   //对右子树递归调用
    cout << root;   //后序,最后输出根节点
}
int main()
{
    string preOrder, inOrder;
    while(cin >> preOrder >> inOrder)
    {
        //参数(前序字符,前序开始p,前序结束p,中序字符,中序开始p,中序结束p)
        postOrder(preOrder, 0, preOrder.size()-1, inOrder, 0, inOrder.size()-1);
        cout << endl;
    }
    return 0;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/05/21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目链接:http://poj.org/problem?id=2255
  • 2. 题目大意:
  • 3. 思考过程:
  • 4. AC代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档