二叉树的中序遍历 递归与迭代

本文详细介绍了二叉树的中序遍历,包括递归和迭代两种方法的实现。通过模板类展示了C++代码,分析了不同版本的时间复杂度。递归方式虽然直观但可能造成较大的栈空间消耗,而迭代版本通过辅助栈解决了这个问题,实现了更高效的空间利用。最后,探讨了两种方法的时间效率差异。
摘要由CSDN通过智能技术生成

1.题目

二叉树中序遍历

2.数据结构与算法

递归:
迭代:引入辅助栈,处理递归嵌套问题。

3.源代码

模板类定义,参考我的文章:《二叉树BT 模板类实现》
这里只给出实现各版本中序遍历的代码。

template<typename T1> 
template<typename T, typename VST> 
static void BinNode<T1>::goAlongLeftBranch(stack<BinNodePosi(T)> &s, BinNodePosi(T) x, VST &visit){
	while(x){
		s.push(x);
		if(HasLChild(x)) x = x->lChild;
	}
}
//中序遍历
template<typename T> 
template<typename VST> 
void BinNode<T>::travIn(VST &visit){
	switch(rand()%2){
	case 1: travIn_R(this, visit);break;
	case 2: travIn_I(this, visit);break;
	}
}
//中序遍历各版本
template<typename T1> 
template<typename T, typename VST> 
void BinNode<T1>::travIn_R(BinNodePosi(T) x, VST &visit){
	if(!x) return;
	travIn_R(x->lChild, visit);
	visit(x->data);
	travIn_R(x->rChild, visit);
}
template<typename T1> 
template<typename T, typename VST> 
void BinNode<T1>::travIn_I(BinNodePosi(T) x, VST &visit){
	stack<BinNodePosi(T)> s;
	while(true){
		goAlongLeftBranch(x);
		if(s.empty()) break;
		x = s.top(); s.pop();
		visit(x);
		x = x->rChild;
	}
}

4.时间复杂度

与先序遍历情况相同。
时间复杂度都是 ο ( n ) \omicron(n) ο(n),但是其系数是大有不同的。
递归:每个递归实例有通用的格式,并不能做到足够的小。
迭代1:引入辅助栈处理递归嵌套问题,使每一帧保存的数据足够小。
左侧链访问入栈,访问栈顶。
嵌套访问右节点左侧链。
其他迭代版本:使用了succ()函数,时间效率降低。
在这里插入图片描述

5.结论

如有错误,请您批评指正。
参考书籍:清华大学《数据结构(C++语言版)》(第三版) 邓俊辉

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值