题目23:从上到下打印二叉树

题目:从上往下打印出二叉树的每一个结点,同一层的结点从左到右顺序打印。
             按层遍历.

/二叉树结点的定义:
struct BinaryTreeNode
{
int m_value;
BinaryTreeNode* m_left;
BinaryTreeNode* m_right;
};

int Print(BinaryTreeNode * head)
{
	queue<BinaryTreeNode *>inque;//队列用来存放子节点

	if(head==NULL)//二叉树为空
		return -1;

	//if(head->m_left==NULL&&head->m_right==NULL)//只有一个结点
	//	return head->m_value;

	inque.push(head);
	while(inque.size())
	{
		BinaryTreeNode *pNode=inque.front();
		inque.pop(); //pop  处理后使得队列里面每次只有一个二叉树结点
		printf("%d",pNode->m_value);//打印根结点

		if(pNode->m_left)    //操作左子树
				inque.push(pNode->m_left);
		if(pNode->m_right)  //操作左子树
			inque.push(pNode->m_right);
	}
}


 

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值