DIY 二叉树的先序非递归遍历



DIY 二叉树的先序非递归遍历

在实现二叉树的非递归遍历的过程中,需要用到一个栈和一个队列;

定义一个bool型常量ok = true;当ok为true是,进入循环,定义指针p,指向根节点;

判断p有几个孩子 {

    如果有两个孩子,则入队;

    入栈;

    如果有一个孩子,判断是左孩子还是右孩子 {

        如果是左孩子 p 指向它的左孩子;

        如果是右孩子 p 指向它的右孩子;

    }

    如果没有孩子,判断是否栈空{

        如果栈不空,取栈顶,p指向栈顶元素的右孩子;

        如果栈空,ok = false;

    }

}

然后把队列中的元素输出,即得到的就是二叉树的先序

void PreambleTraverse(LinkTree T) {	//T指向树的根节点
	stack <LinkTree> S;
	queue <LinkTree> Q;
	LinkTree p = T;
	LinkTree q;
	bool ok = true;
	while(ok) {
		if(p -> L && p -> R)
			S.push(p);
		Q.push(p);
		if(p -> L)
			p = p -> L;
		else if(p -> R)
			p = p -> R;
		else {
			if(!S.empty()){
				q = S.top();
				p = q -> R;
				S.pop();
			}
			else
				ok = false;
		}
	}
	while(!Q.empty()) {
		q = Q.front();
		Q.pop();
		cout << q -> data;
	}
	cout << endl;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值