二叉树镜像问题的循环解法

题目描述:请完成一个函数,输入一个二叉树,该函数输出他的镜像

这个函数主要使用的思想就是循环,上一篇文章主要是转载了剑指offer的题目,但是里面并没有说明怎么用循环解法来解以下为承接上一篇博文的循环解法;

主要思想用队列的思想;

二叉树结点定义如下:

struct  BinaryTreeNode

{

int                                  m_nValue;

 BinaryTreeNode       m_pLeft;

 BinaryTreeNode       m_pRight;

};

主程序如下

void MirrorRecursively(BinaryTreeNode *pNode )

{

   queue<BinaryTreeNode*>p;

   p.push(pNode);

   while(!p.empty())

 {

  BinaryTreeNode *r=p.front;

  p.pop();

  if(r->m_pLeft)

  p.push(r->m_pLeft);

 if(r->m_pRight)

 p.push(r->m_pRight);

 BinaryTreeNode*temp=r->m_pLeft;

 r->m_pLeft=r->m_pRight;

 r->m_pRight=temp;

 }

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值