您好,登錄后才能下訂單哦!
由二叉樹的前序和中序如何得到二叉樹的后序呢?
首先得明白什么是前序、中序、后序。
二叉樹前序:遍歷順序為,根節點、左子樹、右子樹;中序:遍歷順序為,左子樹、根節點、右子樹;后序:遍歷順序為,左子樹、右子樹、根節點
可以發現,二叉樹前序中的第一個節點為樹的根節點root,然后找出root在中序里面的位置,就可以把前序和中序分別劃分為左、右子樹兩個部分,然后遞歸調用即可。
#include<iostream> using namespace std; template<class T> struct BinaryTreeNode { T _data; BinaryTreeNode* _left; BinaryTreeNode* _right; BinaryTreeNode(const T& x) :_data(x) , _left(NULL) , _right(NULL) {} }; template<class T> class BinaryTree { protected: BinaryTreeNode<T>* _root; protected: void _PreOrder(BinaryTreeNode<T>* root) { if (root != NULL) { cout << root->_data << " "; _PreOrder(root->_left); _PreOrder(root->_right); } return; } BinaryTreeNode<T>* _CreateBinary(char* preOrder, char* inOrder, int length) { BinaryTreeNode<T>* root = NULL; if (length == 0) return NULL; int tmp = *preOrder; int index = 0; while (index < length&&inOrder[index] != tmp) index++; if (index < length) { root = new BinaryTreeNode<T>(tmp-'0'); root->_left = _CreateBinary(preOrder + 1, inOrder,index); root->_right = _CreateBinary(preOrder + index + 1, inOrder + index + 1, length - index - 1); } return root; } void _Clear(BinaryTreeNode<T>* root) { if (root) { _Clear(root->_left); _Clear(root->_right); delete root; } } public: BinaryTree() :_root(NULL) {} ~BinaryTree() { _Clear(_root); _root = NULL; } void PreOrder() { _PreOrder(_root); cout << endl; } void CreateBinaryTree(char* preOrder, char* inOrder) { int length = strlen(preOrder); _root = _CreateBinary(preOrder, inOrder,length); } }; void Test1() { char* preOrder = "12473568"; char* inOrder = "47215386"; BinaryTree<int> bt; bt.CreateBinaryTree(preOrder, inOrder); bt.PreOrder(); }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。