非递归遍历二叉树的四种策略-先序、中序、后序和层序

遍历二叉树的递归算法,是比较容易理解的,但是非递归的循环算法不是很容易一眼看穿。下面的五个算法是参考严蔚敏的《数据结构》和USTC的张昱老师的讲义后,写下来的,部分有改动。

 

 先序遍历二叉树算法1

// Copyright (c) 2009, ALex ZhonG. All rights reserved.

Status PreOrderTraverse(BiTree T, Status (Visit *)(TElemType e))
{
	InitStack(S);
	Push(S, T);
	p = T;//或 GetTop(S, p);
	while(!StackEmpty(S) && p)
	{
		while(p)
		{
			if(!Visit(p->data))
				return ERROR;
			Push(p->rchild); 
			p = p->lchild;
		}
		Pop(S, p);
	}
	DestroyStack(S);
	return OK;
}

 

先序遍历二叉树算法2

// Copyright (c) 2009, ALex ZhonG. All rights reserved.

Status PreOrderTraverse(BiTree T, Status (Visit *)(TelemType))
{
	InitStack(S);
	Push(S, T);
	p = T;
	while(!StackEmpty(S) && p)
	{
		while(p)
		{
			if(!Visit(p->data))
				return ERROR;
			Push(S, p);
			p = p->lchild;
		}
		if(!StackEmpty(S))
		{
			Pop(S, p);
			p = p->rchild;
		}
	}
	DestroyStack(S);
	return OK;
}

 

中序遍历二叉树算法

// Copyright (c) 2009, ALex ZhonG. All rights reserved.

Status InOrderTraverse(BiTree T, Status (Visit *)(TelemType e))
{
	InitStack(S);
	Push(S, T)'
	p = T;
	while(!StackEmpty(S) && p)
	{
		while(p)
		{
			Push(S, p);
			p = p ->lchild;
		}
		Pop(S, p);
		if(!Visit(p->data))
			return ERROR;
		p = p->rchild;
	}
	DestroyStack(S);
	return OK;
}

 

后序遍历二叉树算法

// Copyright (c) 2009, ALex ZhonG. All rights reserved.

Status PostOrderTraverse(BiTree T, Status (Visit *)(TelemType e))
{
	InitStack(S);
	Push(S, T);
	p = T;
	while(!StackEmpty(S) && p)
	{
		if(p)
		{//一直走到最左下的结点
			Push(S, p);
			p = p->lchild;
		}
		else
		{//p为NULL时
			GetTop(S, p);
			if(p->rchild && p->rchild != r)
			{//p有右孩子或p的右孩子不是刚刚被访问的
				p = p->rchild;
				Push(S, p);
				p = p->lchild;
			}
			else
			{//p无右孩子或p右孩子刚刚被访问过时
				Pop(S, p);
				Visit(p->data);
				r = p;
				p = NULL;
			}
		}
	}
	DestroyStack(S);
	return OK;
}

 

层序遍历二叉树算法

// Copyright (c) 2009, ALex ZhonG. All rights reserved.

Status LevelOrderTraverse(BiTree T, Status (Visit *)(TelemType e))
{
	InitQueue(Q);
	p = T;
	if(p)
	{
		if(!Visit(p->data)
			return ERROR;
		EnQueue(Q, p->lchild);
		EnQueue(Q, p->rchild);
		while(Q)
		{
			DeQueue(Q, p);
			if(!Visit(p->data))
				return ERROR;
			if(p->lchild)
				EnQueue(Q, p->lchild);
			if(p->rchild)
				EnQueue(Q, p->rchild);
		}
	}
	return OK;
}

 

欢迎讨论、批评和指正!

ALex ZhonG


原文链接: http://blog.csdn.net/poechant/article/details/4811531

转载于:https://my.oschina.net/chen106106/blog/50062

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值