中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

由二叉樹的前序和中序如何得到二叉樹的后序呢?

發布時間:2020-08-01 07:35:27 來源:網絡 閱讀:430 作者:小止1995 欄目:編程語言

由二叉樹的前序和中序如何得到二叉樹的后序呢?

首先得明白什么是前序、中序、后序。

二叉樹前序:遍歷順序為,根節點、左子樹、右子樹;中序:遍歷順序為,左子樹、根節點、右子樹;后序:遍歷順序為,左子樹、右子樹、根節點

可以發現,二叉樹前序中的第一個節點為樹的根節點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();
}

由二叉樹的前序和中序如何得到二叉樹的后序呢?

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

铅山县| 越西县| 平邑县| 长顺县| 巧家县| 高清| 冕宁县| 芜湖市| 江安县| 张家界市| 汪清县| 仁寿县| 南涧| 四平市| 道孚县| 噶尔县| 搜索| 怀来县| 灯塔市| 福清市| 灵丘县| 巢湖市| 莱阳市| 广汉市| 黔江区| 上蔡县| 宿迁市| 高平市| 南宁市| 上杭县| 石柱| 龙里县| 辽中县| 平乡县| 宾阳县| 望奎县| 华坪县| 神池县| 滕州市| 老河口市| 高雄县|