码迷,mamicode.com
首页 > 编程语言 > 详细

毕业了C++二叉树层次遍历

时间:2017-06-23 20:48:53      阅读:113      评论:0      收藏:0      [点我收藏+]

标签:一个   else   color   while   测试   模板   namespace   左右   log   

//代码经过测试,赋值粘贴即可用
#include<iostream> #include<stdio.h> #include<stack> #include<queue> #include<malloc.h> using namespace std; //二叉树结点 typedef struct BTNode{ char data; struct BTNode *lchild; struct BTNode *rchild; }BTNode; //模板先序建立二叉树,大话p187,教科书吧版 BTNode *CreateBiTree()//只需要一个函数 { char ch; BTNode *T; scanf("%c",&ch); if(ch==#) T=NULL; else { T = (BTNode *)malloc(sizeof(BTNode)); T->data = ch; T->lchild = CreateBiTree(); T->rchild = CreateBiTree(); } return T;//返回根节点 } //层次遍历 void LevelOrder(BTNode *T){ //queue<BTNode> queue;大bug隐藏在这个地方;注意queue这个容器装的是什么东西 queue<BTNode *> queue;
queue.push(T); //算法:根结点入队列 while(!queue.empty()){ //若队列非空则循环执行下列的3个步骤 T = queue.front(); //步骤1:对头元素出队,指针从新指向,front()方法是将返回队头元素 printf("%c ",T->data);//队头元素出队然后将队头元素的左右孩子入队 queue.pop();//pop是出队 if(T->lchild != NULL){//步骤2:左子树不空,将左子树入队 queue.push(T->lchild);//入队的就是一个地址元素 } if(T->rchild != NULL){//步骤3:右子树不空,将右子树入队 queue.push(T->rchild); } } } int main() { BTNode *T; T = CreateBiTree();//建立 LevelOrder(T); return 0; }

 

毕业了C++二叉树层次遍历

标签:一个   else   color   while   测试   模板   namespace   左右   log   

原文地址:http://www.cnblogs.com/cs-lcy/p/7071377.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!