根据二叉树前序/中序结果,建立二叉树

2 篇文章 0 订阅

在网上看到一篇文章,感到有些意思,按照他的题目和所提示的原理,编写了如下函数

//根据前序遍历和中序遍历的结果,建立二叉树
void create_str_tree(Node*& pRoot, std::string& pre, std::string& back)
{
	if(pre.size() > 0x00)
	{
		char ch = pre.at(0x00);
		std::string::size_type pos = back.find(ch);
		
		pRoot = new Node();
		pRoot->left = NULL;
		pRoot->right = NULL;
		pRoot->data = ch;
		
		std::string back_left = "";
		std::string back_right = "";
		std::string pre_left = "";
		std::string pre_right = "";
		
		if(pos != std::string::npos)
		{
			back_left  = back.substr(0x00,pos);
			back_right = back.substr(pos + 0x01,back.size());
			
			pre_left   = pre.substr(0x01,pos);
			pre_right  = pre.substr(pos + 0x01,pre.size());
		}
		
		create_str_tree(pRoot->left,pre_left, back_left);
		create_str_tree(pRoot->right,pre_right, back_right);
	}	
}

调用之:
std::string pre = "ABDGCEFH";
std::string back = "DGBAECHF";
create_str_tree(pRoot,pre,back);

输出如下:
前序:A B D G C E F H
中序:D G B A E C H F
后序:G D B E H F C A

可以利用我之前的二叉树代码,打印相应的结果。
这篇文章主要是因为我在网上看到了这边文章,不过只看了原理思想的部分,他的具体代码暂时没参考。
有兴趣的朋友,可以参考下
http://www.360doc.com/content/12/1206/14/7640400_252463767.shtml

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值