根据二叉树前序/中序结果,建立二叉树
来源:互联网 发布:如何统计筛选后的数据 编辑:程序博客网 时间:2024/05/14 02:00
在网上看到一篇文章,感到有些意思,按照他的题目和所提示的原理,编写了如下函数
//根据前序遍历和中序遍历的结果,建立二叉树void create_str_tree(Node*& pRoot, std::string& pre, std::string& back){if(pre.size() > 0x00){char ch = pre.at(0x00);std::string::size_type pos = back.find(ch);pRoot = new Node();pRoot->left = NULL;pRoot->right = NULL;pRoot->data = ch;std::string back_left = "";std::string back_right = "";std::string pre_left = "";std::string pre_right = "";if(pos != std::string::npos){back_left = back.substr(0x00,pos);back_right = back.substr(pos + 0x01,back.size());pre_left = pre.substr(0x01,pos);pre_right = pre.substr(pos + 0x01,pre.size());}create_str_tree(pRoot->left,pre_left, back_left);create_str_tree(pRoot->right,pre_right, back_right);}}调用之:std::string pre = "ABDGCEFH";std::string back = "DGBAECHF";create_str_tree(pRoot,pre,back);输出如下:前序:A B D G C E F H中序:D G B A E C H F后序:G D B E H F C A
可以利用我之前的二叉树代码,打印相应的结果。
这篇文章主要是因为我在网上看到了这边文章,不过只看了原理思想的部分,他的具体代码暂时没参考。
有兴趣的朋友,可以参考下
http://www.360doc.com/content/12/1206/14/7640400_252463767.shtml
- 根据二叉树前序/中序结果,建立二叉树
- 根据前序和中序遍历的结果建立二叉树
- 根据前序跟中序遍历的结果建立二叉树——迭代和递归的方法
- 根据前序和中序建立二叉树
- 根据后序和中序建立二叉树
- 根据二叉树的先序、中序遍历结果重建二叉树
- 重建二叉树---根据前序和中序遍历结果重建二叉树
- 根据二叉树的前序遍历和中序遍历的结果,重建二叉树
- 根据二叉树的先序、中序遍历结果重建二叉树
- 根据二叉树的先序、中序遍历结果重建二叉树
- 根据二叉树的先序遍历建立二叉树
- 根据二叉树前序、中序遍历还原二叉树
- 根据二叉树的先序遍历和中序遍历建立二叉树
- 【二叉树1】根据前序和中序遍历建立一棵二叉树
- 剑指offer--重建二叉树[根据二叉树的先序、中序遍历结果重建二叉树]
- 【暂无】 二叉树 根据遍历结果建立二叉树(build-tree.cpp)
- 二叉树问题-根据前序遍历结果和中序遍历结果得出后序遍历结果
- 根据二叉树的前序遍历和中序遍历结果重建出该二叉树
- BNU29036 状压dp
- 【iPhone开发】ios统计流量代码
- C++ STL 学习总结
- google的一些cool API
- 在导购的田野上(孙彤 )
- 根据二叉树前序/中序结果,建立二叉树
- Ext.Net前后台方法调用示例
- IOS源码开发获取当前的流量信息
- Android declare-styleable:自定义控件的属性(attr.xml,TypedArray)的使用
- Java基本数据类型在常量池中的体现
- 生成全局唯一的ID,java 中
- cookie解决跨子域单点登录说明
- 文件的创建、删除、内容追加、压缩、解压
- 浏览器能够同时加载同一域名下的几个文件?