《剑指offer》重建二叉树
本题来自《剑指offer》 重构二叉树
题目:
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
思路:
二叉树的前序遍历:根左右,第一个值是根节点
二叉树的中序遍历:左根右,根节点的值在中间,左子树的节点在根的左边,右子树的节点在根的右边
首先找到前序的根节点,继而对应到中序中,分离出中序的根左、右子树。
其次对中序的左右子树,对应的找到前序的左右子树。
左、右子树同样是数,所以采用递归的思路进行遍历。
终止条件,当前序只有一个值时候,便是根节点,当没有值就返回None。
C++ Code:(未调通,栈溢出,是边界条件没有调好,后期改)
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
if (pre.size() == ){ //当前序为空时候,返回为空
return NULL;
}else if(pre.size() == ){ //当只有一个元素时候,便直接是根节点
TreeNode* root = new TreeNode(pre[]);
return root;
}else{
std::vector<int> vin_left,vin_right,pre_left,pre_right; //定义前序和中序的左右子节点
for (int i = ;vin[i]!=pre[];i++){ //中序的左节点
vin_left.push_back(vin[i++]);
}
for (int i = vin_left.size()+;i<vin.size();i++){ //中序的右子节点
vin_right.push_back(vin[i]);
}
for (int i = ;i<vin_left.size();i++){ //前序的左子节点
pre_left.push_back(pre[i]);
}
for (int i = pre_left.size()+;i<pre.size();i++){ //前序的右子节点
pre_right.push_back(pre[i]);
}
TreeNode* root = new TreeNode(pre[]); //构造根节点,其值就是前序的第一个值
root->left = reConstructBinaryTree(pre_left,vin_left); //左节点是递归的调用,前左子节点和中左子节点
root->right = reConstructBinaryTree(pre_right,vin_right);//右节点是递归的调用,前右子节点和中右子节点
return root; //将其返回
} }
};
Python Code:
# -*- coding:utf-8 -*-
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
# 返回构造的TreeNode根节点
def reConstructBinaryTree(self, pre, tin):
# write code here
if len(pre) == 0: #当数据中没有数据返回None
return None
elif len(pre) == 1: #当前序中只有一个数时,则为根节点,直接返回
return TreeNode(pre[0])
else:
tin_left = tin[:tin.index(pre[0])] #中序的左子树为从头到前序的根节点
tin_right = tin[tin.index(pre[0])+1:] #中序的右子树为从根节点到尾部全部
pre_left = pre[1:len(tin_left)+1] #前序的左子树为从根节点开始到中序的左子树
pre_right = pre[len(tin_left)+1:] #前序的右子树为中序的右子树
res = TreeNode(pre[0]) #定义根节点
res.left = Solution.reConstructBinaryTree(self,pre_left,tin_left) #递归的调用左子树
res.right = Solution.reConstructBinaryTree(self,pre_right,tin_right)#递归的调用右子树
return res #最终返回根节点
# -*- coding: utf-8 -*-
"""
Created on Mon Apr 8 14:18:46 2019 @author: Administrator
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。
假设输入的前序遍历和中序遍历的结果中都不含重复的数字。
例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 思路:
前序的第一个为根节点,依次找到其左节点的放在一起,右节点的放在一起,递归计算
""" class TreeNode:
def __init__(self, x):
self.val = x
self.left = None
self.right = None
class Solution:
# 返回构造的TreeNode根节点
def reConstructBinaryTree(self, pre, tin):
# write code her
if len(pre) == 0: #如果没有节点就直接返回None
return None
elif len(pre) == 1: #如果只有一个节点就直接是头结点了,直接返回
return TreeNode(pre[0])
else:
tin_left = tin[:tin.index(pre[0])] #截取中左区域
tin_right = tin[tin.index(pre[0])+1:] #截取中右区域
pre_left = pre[1:len(tin_left)+1] #截取前左区域
pre_right = pre[len(tin_left)+1:] #截取前右区域
res = TreeNode(pre[0]) #头结点为前的第0个节点
res.left = Solution.reConstructBinaryTree(self,pre_left,tin_left) #递归,左节点是前左和中左
res.right = Solution.reConstructBinaryTree(self,pre_right,tin_right)#递归,右节点是前右和中右
return res
#前序遍历
def preorder(self,node):
if node:
print(node.val)
Solution.preorder(self,node.left)
Solution.preorder(self,node.right)
# 中序遍历
def inorder(self,node):
if node:
Solution.inorder(self,node.left)
print(node.val)
Solution.inorder(self,node.right)
#后序遍历
def postorder(self,node):
if node:
Solution.postorder(self,node.left)
Solution.postorder(self,node.right)
print(node.val)
if __name__ == '__main__':
pre = [1,2,4,7,3,5,6,8]
tin = [4,7,2,1,5,3,8,6]
solution = Solution()
tree = solution.reConstructBinaryTree(pre,tin)
solution.preorder(tree)
总结:
发现规律,终止和其实条件。
《剑指offer》重建二叉树的更多相关文章
- 剑指Offer——重建二叉树
题目描述: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7 ...
- 剑指Offer——重建二叉树2
Question 输入某二叉树的后序遍历和中序遍历的结果,请重建出该二叉树.假设输入的后序遍历和中序遍历的结果中都不含重复的数字.例如输入后序遍历序列{1, 3, 4, 2}和中序遍历序列{1, 2, ...
- 用js刷剑指offer(重建二叉树)
题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7, ...
- 剑指offer 重建二叉树
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 ...
- 《剑指offer》 二叉树的镜像
本题来自<剑指offer>二叉树的镜像 题目: 操作给定的二叉树,将其变换为源二叉树的镜像. 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 ...
- 剑指Offer:二叉树打印成多行【23】
剑指Offer:二叉树打印成多行[23] 题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 题目分析 Java题解 package tree; import java.uti ...
- 剑指Offer:二叉树中和为某一值的路径【34】
剑指Offer:二叉树中和为某一值的路径[34] 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. ...
- 剑指 Offer 34. 二叉树中和为某一值的路径 + 记录所有路径
剑指 Offer 34. 二叉树中和为某一值的路径 Offer_34 题目详情 题解分析 本题是二叉树相关的题目,但是又和路径记录相关. 在记录路径时,可以使用一个栈来存储一条符合的路径,在回溯时将进 ...
- 剑指 Offer 34. 二叉树中和为某一值的路径
剑指 Offer 34. 二叉树中和为某一值的路径 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下 ...
- 力扣 - 剑指 Offer 27. 二叉树的镜像
题目 剑指 Offer 27. 二叉树的镜像 思路1(递归) 我们可以使用深度优先搜索,先递归到链表的末尾,然后从末尾开始两两交换.就相当于后续遍历而已 记得要先保存下来node.right节点,因为 ...
随机推荐
- ES6走一波 Proxy/Reflect
Proxy:像拦截器,对目标对象修改等进行拦截,是一种元编程(meta programming),即修改JS语言本身. //生成proxy实例,两个参数都是对象,targetObj是要拦截的目标对象, ...
- Invalid bound statement (not found) 找不到mapper 映射文件异常
访问页面报如下错(注意第一行后面的 invalid bound statement (not found)) 这时候再mapper的pom.xml文件要加如下. 否则该节点mybatis的mapper ...
- CSL 的字符串(单调栈)
题目链接:https://ac.nowcoder.com/acm/contest/551/D 题目大意: 题目描述 CSL 以前不会字符串算法,经过一年的训练,他还是不会……于是他打算向你求助. 给定 ...
- vue 学习笔记—路由篇
一.关于三种路由 动态路由 就是path:good/:ops 这种 用 $route.params接收 <router-link>是用来跳转 <router-view> ...
- vue 中通过 ajax 获取数据时,如何避免绑定的数据中出现 property of undefined 错误
参考链接:https://segmentfault.com/q/1010000008264089?_ea=1597485
- 微信小程序滚动Tab选项卡:左右可滑动切换
最终效果如上.问题: 1.tab标题总共8个,所以一屏无法全部显示. 2.tab内容区左右滑动切换时,tab标题随即做标记(active). 3.当active的标题不在当前屏显示时,要使其能显示到当 ...
- python第五天,两个知识点三目运算符和assert抛异常处理。
在python 2.5x之前是没有三目运算符的,但随着语言的发展,在2.5之后就加入了三目运算符 ''' 这里主要将三目运算符 其中也可以通过 x,y=4,5这种方式进行快速的声明变量和对变量赋值. ...
- ECharts.js学习(一) 简单入门
EChart.js 简单入门 最近有一个统计的项目要做,在前端的数据需要用图表的形式展示.网上搜索了一下,发现有几种统计图库. MSChart 这个是Visual Studio里的自带控件,使用比 ...
- 配置Oracle GoldenGate安全性
本章介绍如何配置Oracle GoldenGate安全性. 本章包括以下部分: Overview of Oracle GoldenGate Security Options Encrypting Da ...
- Spring Bean定义配置
1-定义bean 1.1 如果显示的指定了名称,IOC容器就是用这个名称 1.2 若没有显示指定名称,spring自带的BeanNameGenerator会使用自己的规则创建bean的名称(eg: 类 ...