Given preorder and inorder traversal of a tree, construct the binary tree.html
Note:
You may assume that duplicates do not exist in the tree.函数
这道题要求用先序和中序遍从来创建二叉树,跟以前那道Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍历创建二叉树原理基本相同,针对这道题,因为先序的顺序的第一个确定是根,因此原二叉树的根节点能够知道,题目中给了一个很关键的条件就是树中没有相同元素,有了这个条件咱们就能够在中序遍历中也定位出根节点的位置,并以根节点的位置将中序遍历拆分为左右两个部分,分别对其递归调用原函数。代码以下:post
/** * 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 *buildTree(vector<int> &preorder, vector<int> &inorder) { return buildTree(preorder, 0, preorder.size() - 1, inorder, 0, inorder.size() - 1); } TreeNode *buildTree(vector<int> &preorder, int pLeft, int pRight, vector<int> &inorder, int iLeft, int iRight) { if (pLeft > pRight || iLeft > iRight) return NULL; int i = 0; for (i = iLeft; i <= iRight; ++i) { if (preorder[pLeft] == inorder[i]) break; } TreeNode *cur = new TreeNode(preorder[pLeft]); cur->left = buildTree(preorder, pLeft + 1, pLeft + i - iLeft, inorder, iLeft, i - 1); cur->right = buildTree(preorder, pLeft + i - iLeft + 1, pRight, inorder, i + 1, iRight); return cur; } };
咱们下面来看一个例子, 某一二叉树的中序和后序遍历分别为:ui
Preorder: 5 4 11 8 13 9url
Inorder: 11 4 5 13 8 9spa
5 4 11 8 13 9 => 5code
11 4 5 13 8 9 / \htm
4 11 8 13 9 => 5blog
11 4 13 8 9 / \递归
4 8
11 13 9 => 5
11 13 9 / \
4 8
/ / \
11 13 9
作完这道题后,大多人可能会有个疑问,怎么没有由先序和后序遍历创建二叉树呢,这是由于先序和后序遍历不能惟一的肯定一个二叉树,好比下面五棵树:
1 preorder: 1 2 3
/ \ inorder: 2 1 3
2 3 postorder: 2 3 1
1 preorder: 1 2 3
/ inorder: 3 2 1
2 postorder: 3 2 1
/
3
1 preorder: 1 2 3
/ inorder: 2 3 1
2 postorder: 3 2 1
\
3
1 preorder: 1 2 3
\ inorder: 1 3 2
2 postorder: 3 2 1
/
3
1 preorder: 1 2 3
\ inorder: 1 2 3
2 postorder: 3 2 1
\
3
从上面咱们能够看出,对于先序遍历都为1 2 3的五棵二叉树,它们的中序遍历都不相同,而它们的后序遍历却有相同的,因此只有和中序遍历一块儿才能惟一的肯定一棵二叉树。