輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。
思路:
1、找到中序遍歷中根節點的索引i
2、在前序遍歷序列中,找到根節點的左子樹和右子樹
3、在中序遍歷序列中,找到根節點的左子樹和右子樹
4、遞迴
/**
* definition for binary tree
* struct treenode
* };
*/class solution
}for
(int j=
1;jsize()
;j++
)//在前序遍歷序列中,找到根節點的左子樹和右子樹
else
}for
(int j =
0; j < vin.
size()
; j++
)//在中序遍歷序列中,找到根節點的左子樹和右子樹
else
if(j>i)}
t->left =
reconstructbinarytree
(pre_left, vin_left)
;//遞迴
t->right =
reconstructbinarytree
(pre_rigth, vin_right)
;//遞迴
return t;}}
;
4 重建二叉樹
測試通過 時間限制 1秒 空間限制 32768k 題目描述 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。時間限制 1秒空間限制 32768k 本題知識點 查詢 牛客網陣列題目鏈...
4 重建二叉樹
輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建該二叉樹。例如前序遍歷序列和中序遍歷序列為和,假設結果中無重複的數字。重建二叉樹並返回 1 前序遍歷二叉樹的形式為 根節點,左子樹,右子樹 中序遍歷二叉樹的形式為 左子樹,根節點,右子樹 因此我們需要把前序遍歷的第乙個結果new乙個treenode 出來...
4 重建二叉樹
輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。先序序列第乙個數就是根結點而後是左子樹的先序序列和右子樹的先序序列,而中序序列是先是左子樹的中序序列,然後是根結點,最後是右子樹的中...