博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
重建二叉树 POJ 2255
阅读量:6540 次
发布时间:2019-06-24

本文共 2167 字,大约阅读时间需要 7 分钟。

数据结构中的经典问题之一就是根据二叉树的某种遍历序列重建二叉树,比如给出前序和中序序列,但是要求输出后序遍历的结果。

这里仅仅帖一份根据前序和中序遍历重建二叉树的代码吧(要输出后序遍历的结果,只要添加一个后序遍历函数即可),正好是POJ 2255的答案。

#include <iostream>
#include
<map>
#include
<utility>
#include
<functional>
#include
<string>
#include
<stack>
using namespace
std;
typedef
char
Type;
struct
Node
{
     Node( Node
*t ) : data( t->data ), lChild( t->lChild ), rChild( t->
rChild ) {}
     Node( Type d ) : data( d ), lChild( NULL ), rChild( NULL ) {}
    
struct Node*
lChild;
    
struct Node*
rChild;
     Type data;
};
Node
*rebuildFromPreInOrder( string &preOrder, string &
inOrder )
{
    
// preOrder and inOrder always have equal length.
    if ( preOrder.size() == 0
)
        
return
NULL;
    
if ( preOrder.size() == 1
)
        
return new Node( preOrder[0
] );
    
// get the root
     Node *root = new Node( preOrder[0
] );
    
//
divide inOrder sequence into two sub sequences
    
// by the first node of preOrder sequence.
     size_t rootPos = inOrder.find( preOrder[0
] );
    
string left_sub_inorder = inOrder.substr( 0
, rootPos );
    
string right_sub_inorder = inOrder.substr( rootPos + 1
);
     size_t left_size
=
left_sub_inorder.size();
    
    
// divide preOrder sequence into two sub sequences by their length.
    string left_sub_preorder = preOrder.substr( 1
, left_size );
    
string right_sub_preorder = preOrder.substr( left_size + 1
);
    
// recursive rebuilding and connect with root
     root->lChild =
rebuildFromPreInOrder( left_sub_preorder, left_sub_inorder );
     root
->rChild =
rebuildFromPreInOrder( right_sub_preorder, right_sub_inorder );
    
return
root;
}
void PostOrder( Node *root, void (*visit)(Node*
) )
{
     stack
<Node*>
s;
     Node
*cur =
root;
     Node
*visited =
NULL;
    
while( ! s.empty() || cur !=
NULL )
     {
        
while( cur !=
NULL )
         {     s.push( cur ); cur
= cur->
lChild; }
         cur
= s.top();  // check but no visit.
        
if( cur->rChild == visited || cur->rChild ==
NULL )
         {
             visit( cur ); s.pop();
             visited
=
cur;
             cur
= NULL; // no current node, must pop.
         }
        
else
             cur
= cur->
rChild;
     }
}
void visit( Node *
t )
{
     cout
<<t->
data;
}
int
main()
{
    
while ( !
cin.eof() )
     {
        
string pre, in
;
         cin
>>pre>>in
;
         Node
*root = rebuildFromPreInOrder( pre, in
);
         PostOrder( root, visit );
         cout
<<
endl;
     }
    
    
return 0
;
}

转载于:https://www.cnblogs.com/microgrape/archive/2011/05/12/2043932.html

你可能感兴趣的文章
架构师速成-架构目标之伸缩性\安全性
查看>>
linux中iptables设置自建dns服务器的端口
查看>>
有向图的拓扑排序算法JAVA实现
查看>>
am335x 电容屏驱动添加。
查看>>
Nginx配置中的log_format用法梳理(设置详细的日志格式)
查看>>
从 JavaScript 到 TypeScript
查看>>
Linux常用的服务器构建
查看>>
深入了解 Weex
查看>>
Zeppelin Prefix not found.
查看>>
linux 的网络设置
查看>>
首届“欧亚杯”象翻棋全国团体邀请赛圆满收评!
查看>>
编译tomcat
查看>>
oracle-xe手工创建数据库
查看>>
我的友情链接
查看>>
UG中卸载被占用的DLL
查看>>
eclipse 设置注释模板详解,与导入模板方法介绍总结
查看>>
Cocos2d-x3.2 文字显示
查看>>
mongodb group
查看>>
session_start()放置位置的不正确引发的ROOT常量 未定义的错误
查看>>
如何设定VDP同时备份的任务数?
查看>>