从上到下遍历二叉树

思路:

即二叉树的层序遍历。可以使用一个辅助队列,首先将二叉树的根节点入队,然后打印根结点的值,接着判断根结点

是否有左右孩子,如果有,将左右孩子入队。如此循环直到队列为空。

代码:

/*
从上到下遍历二叉树
by Rowandjj
2014/8/1
*/
#include<iostream>
using namespace std;
typedef struct _BNODE_
{
	int data;
	struct _BNODE_ *lChild;
	struct _BNODE_ *rChild;
}BNode,*pTree,*pNode;
typedef struct _QUEUENODE_
{
	pNode data;
	struct _QUEUENODE_ *next;
}QNode,*pQNode;
typedef struct _QUEUE_
{
	pQNode pHead;
	pQNode pTail;
}Queue,*pQueue;
void InitQueue(pQueue pQ)
{
	pQ->pHead = pQ->pTail = (pQNode)malloc(sizeof(QNode));
	if(pQ->pHead == NULL)
	{
		exit(-1);
	}
	pQ->pHead->next = NULL;
}
void Enqueue(pQueue pQ,pNode data)
{
	if(pQ == NULL || data == NULL)
	{
		return;
	}
	pQNode pNew = (pQNode)malloc(sizeof(QNode));
	if(!pNew)
	{
		exit(-1);
	}
	pNew->data = data;
	pNew->next = NULL;
	pQ->pTail->next = pNew;
	pQ->pTail = pNew;
}
pNode Dequeue(pQueue pQ)
{
	if(pQ == NULL)
	{
		return NULL;
	}
	pQNode pDel = pQ->pHead->next;
	if(pDel == NULL)
	{
		return NULL;
	}
	pNode data = pDel->data;
	if(pDel == pQ->pTail)
	{
		pQ->pTail = pQ->pHead;
	}
	pQ->pHead->next = pDel->next;
	free(pDel);
	return data;
}
void Destroy(pQueue pQ)
{
	if(pQ == NULL)
	{
		return;
	}
	pNode pTemp;
	while((pTemp = Dequeue(pQ)) != NULL)
	{
		free(pTemp);
	}
	free(pQ->pHead);
}
//层次遍历
void LevelTraverse(pTree pT)
{
	if(pT == NULL)
	{
		return;
	}
	Queue q;
	InitQueue(&q);
	Enqueue(&q,pT);
	pNode pTemp;
	while((pTemp = Dequeue(&q)) != NULL)
	{
		cout<<pTemp->data<<" ";
		if(pTemp->lChild)
		{
			Enqueue(&q,pTemp->lChild);
		}
		if(pTemp->rChild)
		{
			Enqueue(&q,pTemp->rChild);
		}
	}
	Destroy(&q);
}
void Create(pTree *pT)
{
	int data;
	cin>>data;
	if(data != -1)
	{
		*pT = (pTree)malloc(sizeof(BNode));
		if(*pT == NULL)
		{
			exit(-1);
		}
		(*pT)->lChild = NULL;
		(*pT)->rChild = NULL;
		(*pT)->data = data;
		Create(&(*pT)->lChild);
		Create(&(*pT)->rChild);
	}
}
int main()
{
	pTree pT= NULL;
	Create(&pT);
	LevelTraverse(pT);
	return 0;
}

测试:

从上到下遍历二叉树

时间: 2024-10-25 14:32:22

从上到下遍历二叉树的相关文章

从上往下打印二叉树(分层遍历)

从上往下打印二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 从上到下打印二叉树的规律:每一次打印一个节点的时候,如果该节点有子节点,则把该节点的子节点放到一个队列的末尾.接下来到队列的头部取出最早进入队列的节点,重复前面的打印操作,直到队列中所有的节点都被打印出来为止. struct TreeNode { int val; TreeNode* left; TreeNode* right; }; void LevelOrder(BinaryTreeNode* root) { if (roo

剑指Offer面试题23(Java版):从上往下打印二叉树

题目:从上往下打印二叉树的每个结点,同一层的结点按照从左到右的顺序打印.例如输入下图的二叉树,则一次打印出8,6,10,5,7,9,11. 这道题实质上考察的就是树的遍历算法,只是这种遍历不是我们熟悉的前序.中序或者后序遍历.由于我们不太熟悉这种按层遍历的方法,可能已下载也想不清楚遍历的过程. 因为按层打印的顺序决定应该先打印的根节点,所以我们从树的根节点开始分析.为了接下来能够打印8的结点的两个子节点,我们应该在遍历到该结点时把值为6和10的两个结点保存到一个容器中,现在容器内就有两个结点了.

从上往下打印二叉树-剑指Offer

从上往下打印二叉树 题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路 数据结构:队列 将树按层遍历,先将根节点的左右子节点先后进入队列,然后再先后从队列取出,然后将取出的节点的左右子节点再入队列 循环进行,直到队列为空 代码 import java.util.ArrayList; import java.util.LinkedList; import java.util.Queue; /** public class TreeNode { int val = 0; Tree

数据结构-从上往下打印二叉树

题目:从上往下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 分析:其实就是按层的遍历方式 #include <iostream> #include <deque> using namespace std; struct BinaryTree{ int data; BinaryTree* lchild; BinaryTree* rchild; }; void PrintLeverTree(BinaryTree* root){ if(root == NULL){ ret

从上往下打印二叉树(剑指offer)+队列的应用

从上往下打印二叉树 参与人数:1577时间限制:1秒空间限制:32768K 通过比例:25.53% 最佳记录:0 ms|0K(来自  dust347) 题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 题意:就是树的层次遍历.想象一下,从根结点依次往下,每行从左到右,这不就是是入队和出队的操作嘛! so...代码很容易吧. /* struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; Tr

剑指 offer-从上往下打印二叉树

题目:从上往下打印二叉树 题目描述:从上往下打印出二叉树的每个节点,同层节点从左至右打印 思路:考察二叉树的 层序遍历,通常借助使用一个队列或一个栈来完成 若是要求每层数据从左到右保存则用队列,若是要求每层数据从右到左保存则用栈(这种要求一般出现在“之”字型遍历 二叉树的题上) 题目本身好像要求只能用ArrayList,我这里直接用队列解了 1 import java.util.ArrayList; 2 import java.util.LinkedList; 3 import java.uti

【Java】 剑指offer(31)从上往下打印二叉树

本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 (一)从上往下打印出二叉树的每个结点,同一层的结点按照从左到右的顺序打印. (二)从上到下按层打印二叉树,同一层的结点按从左到右的顺序打印,每一层打印到一行. (三)请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推. 思路 (一)不分行从上往下打印二叉树:该题即为对二叉树的层

剑指Offer对答如流系列 - 从上往下打印二叉树

面试题32:从上往下打印二叉树 题目描述 树的结构定义如下: public class Node{ int e; Node left; Node right; Node(int x) { e = x; } } (一)不分行从上到下打印二叉树 从上往下打印出二叉树的每个结点,同一层的结点按照从左到右的顺序打印. 比如下面二叉树,输出顺序为 8 6 10 5 7 9 11 (二)分行从上到下打印二叉树 从上到下按层打印二叉树,同一层的结点按从左到右的顺序打印,每一层打印到一行. 比如下面二叉树,输出

剑指OFFER之从上往下打印二叉树(九度OJ1523)

题目描述: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 输入: 输入可能包含多个测试样例,输入以EOF结束.对于每个测试案例,输入的第一行一个整数n(1<=n<=1000, :n代表将要输入的二叉树元素的个数(节点从1开始编号).接下来一行有n个数字,代表第i个二叉树节点的元素的值.接下来有n行,每行有一个字母Ci.Ci='d'表示第i个节点有两子孩子,紧接着是左孩子编号和右孩子编号.Ci='l'表示第i个节点有一个左孩子,紧接着是左孩子的编号.Ci='r'表示第i个节点有一个右孩