#include <iostream> using namespace std;
struct BinaryTreeNode { int value; BinaryTreeNode* left; BinaryTreeNode* right; };
BinaryTreeNode* rebulidBinaryTreeCore(int* startPreOrder, int* endPreOrder, int* startInOrder, int* endInOrder) {
BinaryTreeNode* rootNode = new BinaryTreeNode(); rootNode->value = startPreOrder[0]; rootNode->left = NULL; rootNode->right = NULL;
if(startPreOrder == endPreOrder) { if(startInOrder == endInOrder && *startPreOrder == *startInOrder) { return rootNode; } else { throw ("Invalid input."); } }
int* rootIndex = startInOrder; while(rootIndex <= endInOrder && *rootIndex != rootNode->value) { rootIndex++; } if(rootIndex == endInOrder && *rootIndex != rootNode->value) { throw ("Invalid input."); }
int leftTreeLength = rootIndex - startInOrder; if(leftTreeLength > 0) { rootNode->left = rebulidBinaryTreeCore(startPreOrder + 1, startPreOrder + leftTreeLength, startInOrder, rootIndex - 1); }
if(leftTreeLength < endPreOrder - startPreOrder) { rootNode->right = rebulidBinaryTreeCore(startPreOrder + leftTreeLength + 1, endPreOrder, rootIndex + 1, endInOrder); }
return rootNode; }
BinaryTreeNode* rebulidBinaryTree(int* preOrder, int* inOrder, int n) { if(preOrder == NULL || inOrder == NULL || n <= 0) { return NULL; }
return rebulidBinaryTreeCore(preOrder, preOrder + n -1, inOrder, inOrder + n - 1); }
void printPostOrder(BinaryTreeNode* root) { if(root!= NULL) { if(root->left != NULL) { printPostOrder(root->left); } if(root->right != NULL) { printPostOrder(root->right); } cout << root->value << " "; } return ; }
int main() { int preOrder[8] = {1,2,4,7,3,5,6,8}; int inOrder[8] = {4,7,2,1,5,3,8,6}; BinaryTreeNode* root = rebulidBinaryTree(preOrder, inOrder, 8); printPostOrder(root); return 0; }
|