【算法百题之十一】二叉树的深度优先遍历

   【算法百题之十一】二叉树的深度优先遍历

       大家好,我是Lampard~~

       很高兴又能和大家见面了,接下来准备系列更新的是算法题,一日一练,早日升仙!

 

       今天的问题是:

        实现二叉树的深度优先遍历。

        

        我的思路:

       

      实现深度遍历,我们希望输出的结果是:A,B,G,F,Z,E,D,C

      为了实现这一功能,我们可以利用栈这个小帮手来完成。

      我们可以利用栈先入后出的特性,把右子树先压入栈,

      然后把左子树后入栈,继而输出,这样就可以达到深度遍历的效果。

   

     

相关代码:

void BinaryTree::ShenDu()
{
	// 深度遍历的实现
	stack<BinaryTreeNode*> myStack;
	myStack.push(root);
	BinaryTreeNode* node;

	while (myStack.size() != 0)
	{
		node = myStack.top();
		cout << node->getData() << " ";
		myStack.pop();                   
		                           
		if (node->getRightChild() != NULL)
			myStack.push(node->getRightChild());
		
		if (node->getLeftChild() != NULL)
			myStack.push(node->getLeftChild());

	}

}

    我们需要node这个暂存栈顶元素的变量是因为:

   我们要在两个if之前把栈顶元素出栈,不然的话一旦发现有符合的元素,

   栈顶的元素就会换了个人,这样会使整个程序无限循环。

  如果我们想构造一个上图的树的话,我们前序插入元素的顺序应该是:

A,B,G, # , #,F, Z, #,#,E,#,#,D,#,C,#,#

具体的创造函数请看算法百题之九

 

测试代码:

cout << endl;
	cout << "深度优先遍历的结果为:" << endl;
	myTree->ShenDu();

测试结果:

 

OK,今天的博客就到这里,谢谢大家!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lampard杰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值