码迷,mamicode.com
首页 > 其他好文 > 详细

已知前序中序求后序-二叉树

时间:2017-07-22 12:12:44      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:style   turn   竞赛   ring   参考   rt4   main   namespace   unsigned   

writer:pprp

思路很容易理解,但是实现还是有一点难度,容易错

参考书目:《算法竞赛宝典》

代码如下:

//已知前序中序,求后序
#include <iostream>

using namespace std;

//a是前序,b是中序
void hwg(string a,string b)
{
    int ll,lr;

    for(unsigned int i = 0; i < b.length(); i++)
    {
        if(a[0] == b[i])    //找到根节点
        {
            ll = i;                   //分别计算出左右子树的长度
            lr = b.length()-1-ll;
            if(ll)                     //
            {
                string part1(a,1,ll),part2(b,0,11);
                hwg(part1,part2);
            }
            if(lr)
            {
                string part3(a,1+ll,lr),part4(b,1+ll,lr);
                hwg(part3,part4);
            }
            cout << a[0];
            break;
        }
    }
}

int main()
{
    string a,b;
    cout <<"请输入前序:"<<endl;
    cin >> a;
    cout <<"请输入中序:"<<endl;
    cin >> b;
    cout <<"后序为:"<<endl;
    hwg(a,b);
    return 0;
}

 

已知前序中序求后序-二叉树

标签:style   turn   竞赛   ring   参考   rt4   main   namespace   unsigned   

原文地址:http://www.cnblogs.com/ilovelianghui/p/7220630.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!