105 從前序與中序遍歷序列構造二叉樹

2022-08-17 07:21:18 字數 756 閱讀 7621

題目描述:

根據一棵樹的前序遍歷與中序遍歷構造二叉樹。

注意:你可以假設樹中沒有重複的元素。

例如,給出

前序遍歷 preorder = [3,9,20,15,7]

中序遍歷 inorder = [9,3,15,20,7]

返回如下的二叉樹:

思路:採用遞迴的思想

/*

* * definition for a binary tree node.

* struct treenode

* }; */

class

solution

treenode* build(vector& preorder, int pl,int pr,vector& inorder,int il,int

ir)

int lsize = i -il;

int rsize = ir -i;

if(lsize>0

) root->left = build(preorder,pl+1,pl+lsize,inorder,il,il+lsize-1); //

注意中序遍歷的右邊界

if(rsize>0

) root->right = build(preorder,pl+lsize+1,pr,inorder,il+lsize+1

,ir);

return

root;}};

Leetcode 從前序與中序遍歷序列構造二叉樹

根據一棵樹的前序遍歷與中序遍歷構造二叉樹。注意 你可以假設樹中沒有重複的元素。例如,給出 前序遍歷 preorder 3,9,20,15,7 中序遍歷 inorder 9,3,15,20,7 返回如下的二叉樹 3 9 20 15 7 definition for a binary tree node...

105 從前序與中序遍歷序列構造二叉樹

如題,根據前序與中序遍歷序列構造二叉樹 整體思路 前序遍歷的第乙個元素,必然是二叉樹的根節點 在中序遍歷中找到前序遍歷第乙個元素的位置 該位置左邊的所有點都是二叉樹的左子樹元素,該位置右邊的所有點都是二叉樹的右子樹元素 思路一 遞迴 字典 由整體思路可以構建子函式用於遞迴,不斷求子樹的左右子樹,直到...

105 從前序與中序遍歷序列構造二叉樹

根據一棵樹的前序遍歷與中序遍歷構造二叉樹。注意 你可以假設樹中沒有重複的元素。例如,給出 前序遍歷 preorder 3,9,20,15,7 中序遍歷 inorder 9,3,15,20,7 返回如下的二叉樹 3 9 20 15 7 def buildtree2 preorder,inorder i...