第11周项目1-验证算法(1)层次遍历算法的验证

问题:

[cpp]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. /*  
  2. Copyright (c)2016,烟台大学计算机与控制工程学院  
  3. All rights reserved.  
  4. 文件名称:项目1-1.cbp  
  5. 作    者:陈晓琳  
  6. 完成日期:2016年11月10日  
  7. 版 本 号:v1.0  
  8. 问题描述:实现二叉树的层次遍历算法,并对用”A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))”创建的二叉树进行测试。   
  9. 输入描述:无  
  10. 程序输出:测试数据  
  11. */    

头文件及功能函数详见【二叉树算法库】

代码:

[cpp]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. void LevelOrder(BTNode *b)    
  2. {    
  3.     BTNode *p;    
  4.     BTNode *qu[MaxSize];    //定义环形队列,存放节点指针    
  5.     int front,rear; //定义队头和队尾指针    
  6.     front=rear=-1;      //置队列为空队列    
  7.     rear++;    
  8.     qu[rear]=b;     //根节点指针进入队列    
  9.     while (front!=rear) //队列不为空    
  10.     {    
  11.         front=(front+1)%MaxSize;    
  12.         p=qu[front];        //队头出队列    
  13.         printf("%c ",p->data);  //访问节点    
  14.         if (p->lchild!=NULL)    //有左孩子时将其进队    
  15.         {    
  16.             rear=(rear+1)%MaxSize;    
  17.             qu[rear]=p->lchild;    
  18.         }    
  19.         if (p->rchild!=NULL)    //有右孩子时将其进队    
  20.         {    
  21.             rear=(rear+1)%MaxSize;    
  22.             qu[rear]=p->rchild;    
  23.         }    
  24.     }    
  25. }    
  26.     
  27. int main()    
  28. {    
  29.     BTNode *b;    
  30.     CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))");    
  31.     printf("二叉树b: ");    
  32.     DispBTNode(b);    
  33.     printf("\n");    
  34.     printf("层次遍历序列:\n");    
  35.     LevelOrder(b);    
  36.     DestroyBTNode(b);    
  37.     return 0;    
  38. }    

运行结果:


知识点总结:

层次遍历算法。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值