輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如,輸入前序遍歷序列{1,2,4,7,3,5,6,8},中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。ui
1 namespace JianZhiOffer 2 { 3 public class TreeNode 4 { 5 public int val; 6 public TreeNode left; 7 public TreeNode right; 8 9 public TreeNode(int x) 10 { 11 val = x; 12 } 13 } 14 15 class ReBuiltBinaryTree 16 { 17 public TreeNode reConstructBinaryTree(int[] pre, int[] tin) 18 { 19 // write code here 20 if (pre == null || tin == null) 21 { 22 return null; 23 } 24 25 return reCBT(pre, 0, pre.Length - 1, tin, 0, tin.Length - 1); 26 } 27 28 /// <summary> 29 /// 利用遞歸分別處理左右子樹 30 /// </summary> 31 /// <param name="pre">前序序列</param> 32 /// <param name="headPre">前序序列首元素</param> 33 /// <param name="tailPre">前序序列尾元素</param> 34 /// <param name="tin">中序序列</param> 35 /// <param name="headTin">中序序列首元素</param> 36 /// <param name="tailTin">中序序列尾元素</param> 37 /// <returns></returns> 38 public TreeNode reCBT(int[] pre, int headPre, int tailPre, int[] tin, int headTin, int tailTin) 39 { 40 if (headPre > tailPre || headTin > tailTin) 41 { 42 return null; 43 } 44 45 // 前序序列的首元素爲二叉樹的根結點 46 TreeNode rootNode = new TreeNode(pre[headPre]); 47 48 // 遍歷中序序列, 若是遇到和根結點相等的元素, 則前面的元素爲左子樹的結點, 後面的元素爲右子樹的結點 49 // 左子樹元素個數:i - headTin + 1 50 // 前序序列中, 左子樹首元素:headPre + 1, 左子樹尾元素:headPre + 1 + (i - headTin - 1) 51 // 右子樹元素個數:tailTin - i + 1 52 // 前序序列中, 右子樹首元素:headPre + (i - headTin + 1), 右子樹尾元素:tailPre 53 for (int i = headTin; i <= tailTin; i++) 54 { 55 if (rootNode.val == tin[i]) 56 { 57 rootNode.left = reCBT(pre, headPre + 1, headPre + (i - headTin), tin, headTin, i - 1); 58 rootNode.right = reCBT(pre, headPre + (i - headTin) + 1, tailPre, tin, i + 1, tailTin); 59 } 60 } 61 62 return rootNode; 63 } 64 } 65 }