重建二叉树
来源:互联网 发布:java写的小游戏 编辑:程序博客网 时间:2024/06/05 17:15
题目描述
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
#include<iostream>#include"BinaryTree.h"using namespace std;BinaryTreeNode* ConstructTreeCore(int* startPreOrder, int* endPreOrder, int* startInOrder, int* endInOrder ){int rootValue = *startPreOrder;BinaryTreeNode* root = new BinaryTreeNode();root->m_nValue = rootValue;root->m_pLeft = root->m_pRight = NULL;if(startPreOrder == endPreOrder ){if(startInOrder == endInOrder && *startPreOrder == *startInOrder)return root;else{throw exception("Invaliad input");}}int *rootInOrder = startInOrder;while (rootInOrder < endInOrder && *rootInOrder != rootValue)rootInOrder++;if(rootInOrder == endInOrder && *rootInOrder != rootValue)throw exception("Invalid input");int leftLength = rootInOrder - startInOrder;int* leftPreNode = startPreOrder + leftLength;if(leftLength > 0)root ->m_pLeft = ConstructTreeCore(startPreOrder+1, leftPreNode, startInOrder, rootInOrder-1 );if(endInOrder - startInOrder > leftLength)root ->m_pRight = ConstructTreeCore(leftPreNode+1, endPreOrder, rootInOrder+1, endInOrder );return root;}BinaryTreeNode* ConstructTree(int* preOrder, int* inOrder,int length){if(preOrder == NULL || inOrder == NULL || length <=0)return NULL;int* startPreOrder = preOrder;int* endPreOrder = preOrder + length-1;int* startInOrder = inOrder;int* endInOrder = inOrder + length-1;return ConstructTreeCore(startPreOrder, endPreOrder, startInOrder, endInOrder );}
// ====================测试代码====================void Test(char* testName, int* preorder, int* inorder, int length){ if(testName != NULL) printf("%s begins:\n", testName); printf("The preorder sequence is: "); for(int i = 0; i < length; ++ i) printf("%d ", preorder[i]); printf("\n"); printf("The inorder sequence is: "); for(int i = 0; i < length; ++ i) printf("%d ", inorder[i]); printf("\n"); try { BinaryTreeNode* root = ConstructTree(preorder, inorder, length); PrintTree(root); DestroyTree(root); } catch(exception& exception) { printf("Invalid Input.\n"); }}// 普通二叉树// 1// / \// 2 3 // / / \// 4 5 6// \ /// 7 8void Test1(){ const int length = 8; int preorder[length] = {1, 2, 4, 7, 3, 5, 6, 8}; int inorder[length] = {4, 7, 2, 1, 5, 3, 8, 6}; Test("Test1", preorder, inorder, length);}// 所有结点都没有右子结点// 1// / // 2 // / // 3 // /// 4// /// 5void Test2(){ const int length = 5; int preorder[length] = {1, 2, 3, 4, 5}; int inorder[length] = {5, 4, 3, 2, 1}; Test("Test2", preorder, inorder, length);}// 所有结点都没有左子结点// 1// \ // 2 // \ // 3 // \// 4// \// 5void Test3(){ const int length = 5; int preorder[length] = {1, 2, 3, 4, 5}; int inorder[length] = {1, 2, 3, 4, 5}; Test("Test3", preorder, inorder, length);}// 树中只有一个结点void Test4(){ const int length = 1; int preorder[length] = {1}; int inorder[length] = {1}; Test("Test4", preorder, inorder, length);}// 完全二叉树// 1// / \// 2 3 // / \ / \// 4 5 6 7void Test5(){ const int length = 7; int preorder[length] = {1, 2, 4, 5, 3, 6, 7}; int inorder[length] = {4, 2, 5, 1, 6, 3, 7}; Test("Test5", preorder, inorder, length);}// 输入空指针void Test6(){ Test("Test6", NULL, NULL, 0);}// 输入的两个序列不匹配void Test7(){ const int length = 7; int preorder[length] = {1, 2, 4, 5, 3, 6, 7}; int inorder[length] = {4, 2, 8, 1, 6, 3, 7}; Test("Test7: for unmatched input", preorder, inorder, length);}int main(int argc, char* argv[]){ Test1(); Test2(); Test3(); Test4(); Test5(); Test6(); Test7(); return 0;}
0 0
- 3.9重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 二叉树的重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 二叉树重建
- 二叉树重建
- 重建二叉树
- 重建二叉树
- 重建二叉树
- 什么是Git和Github
- jquery 动态控制表格,添加,删除,上移,下移,排序
- DOM(一)-15-(通过节点层次关系获取节点)
- 最新驾校模拟考试题库大全接口实现及代码示例
- 小考试 纪念一下
- 重建二叉树
- UNIX Tutorial Two_files
- iOS下nil 、NULL、 Nil 、NSNull的区别你造吗
- POJ 3984 迷宫问题 (BFS)
- linux调试工具
- android webview js alert对话框 不能弹出 解决办法
- DOM(一)-16-(节点操作-创建并添加_1)
- Vim编辑器——入门学习
- spring Security 登录验证