第11周上机实践项目1—二叉树算法验证(1)层次遍历算法的验证
来源:互联网 发布:windows 打开tar.gz 编辑:程序博客网 时间:2024/04/19 04:18
问题及代码:
测试函数:main.cpp,完成相关的测试工作;
/**Copyright(c)2015,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:test.cpp *作者:颜肖璇 *完成日期:2015年11月9日 *版本号:v1.0 /* *问题描述: 实现二叉树的层次遍历算法,并对用”A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))”创建的二叉树进行测试。 *输入描述: *程序输出: */ #include <stdio.h>#include "btree.h"void LevelOrder(BTNode *b){ BTNode *p; BTNode *qu[MaxSize]; //定义环形队列,存放节点指针 int front,rear; //定义队头和队尾指针 front=rear=-1; //置队列为空队列 rear++; qu[rear]=b; //根节点指针进入队列 while (front!=rear) //队列不为空 { front=(front+1)%MaxSize; p=qu[front]; //队头出队列 printf("%c ",p->data); //访问节点 if (p->lchild!=NULL) //有左孩子时将其进队 { rear=(rear+1)%MaxSize; qu[rear]=p->lchild; } if (p->rchild!=NULL) //有右孩子时将其进队 { rear=(rear+1)%MaxSize; qu[rear]=p->rchild; } }}int main(){ BTNode *b; CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))"); printf("二叉树b: "); DispBTNode(b); printf("\n"); printf("层次遍历序列:\n"); LevelOrder(b); DestroyBTNode(b); return 0;}
头文件:btree.h,包含定义顺序表数据结构的代码、宏定义、要实现算法的函数的声明;
#ifndef BTREE_H_INCLUDED#define BTREE_H_INCLUDED#define MaxSize 100typedef char ElemType;typedef struct node{ ElemType data; //数据元素 struct node *lchild; //指向左孩子 struct node *rchild; //指向右孩子} BTNode;void CreateBTNode(BTNode *&b,char *str); //由str串创建二叉链BTNode *FindNode(BTNode *b,ElemType x); //返回data域为x的节点指针BTNode *LchildNode(BTNode *p); //返回*p节点的左孩子节点指针BTNode *RchildNode(BTNode *p); //返回*p节点的右孩子节点指针int BTNodeDepth(BTNode *b); //求二叉树b的深度void DispBTNode(BTNode *b); //以括号表示法输出二叉树void DestroyBTNode(BTNode *&b); //销毁二叉树#endif // BTREE_H_INCLUDED
源文件:btree.cpp,包含实现各种算法的函数的定义;
#include <stdio.h>#include <malloc.h>#include "btree.h"void CreateBTNode(BTNode *&b,char *str) //由str串创建二叉链{ BTNode *St[MaxSize],*p=NULL; int top=-1,k,j=0; char ch; b=NULL; //建立的二叉树初始时为空 ch=str[j]; while (ch!='\0') //str未扫描完时循环 { switch(ch) { case '(': top++; St[top]=p; k=1; break; //为左节点 case ')': top--; break; case ',': k=2; break; //为右节点 default: p=(BTNode *)malloc(sizeof(BTNode)); p->data=ch; p->lchild=p->rchild=NULL; if (b==NULL) //p指向二叉树的根节点 b=p; else //已建立二叉树根节点 { switch(k) { case 1: St[top]->lchild=p; break; case 2: St[top]->rchild=p; break; } } } j++; ch=str[j]; }}BTNode *FindNode(BTNode *b,ElemType x) //返回data域为x的节点指针{ BTNode *p; if (b==NULL) return NULL; else if (b->data==x) return b; else { p=FindNode(b->lchild,x); if (p!=NULL) return p; else return FindNode(b->rchild,x); }}BTNode *LchildNode(BTNode *p) //返回*p节点的左孩子节点指针{ return p->lchild;}BTNode *RchildNode(BTNode *p) //返回*p节点的右孩子节点指针{ return p->rchild;}int BTNodeDepth(BTNode *b) //求二叉树b的深度{ int lchilddep,rchilddep; if (b==NULL) return(0); //空树的高度为0 else { lchilddep=BTNodeDepth(b->lchild); //求左子树的高度为lchilddep rchilddep=BTNodeDepth(b->rchild); //求右子树的高度为rchilddep return (lchilddep>rchilddep)? (lchilddep+1):(rchilddep+1); }}void DispBTNode(BTNode *b) //以括号表示法输出二叉树{ if (b!=NULL) { printf("%c",b->data); if (b->lchild!=NULL || b->rchild!=NULL) { printf("("); DispBTNode(b->lchild); if (b->rchild!=NULL) printf(","); DispBTNode(b->rchild); printf(")"); } }}void DestroyBTNode(BTNode *&b) //销毁二叉树{ if (b!=NULL) { DestroyBTNode(b->lchild); DestroyBTNode(b->rchild); free(b); }}
运行结果:
知识点总结:
二叉树的层次遍历算法。
学习心得:
改变测试数据进行重复测试,从更多角度体会算法,以达到逐渐掌握算法的程度。 0 0
- 第11周上机实践项目1—二叉树算法验证(1)层次遍历算法的验证
- 第11周 项目1 - 二叉树算法验证—层次遍历算法的验证
- 第11周上机实践项目1—二叉树算法验证(2)二叉树构造算法的验证
- 第11周实践项目1验证算法—层次遍历算法的验证
- 【第11周 项目1 - 二叉树算法验证(1)层次遍历算法的验证】
- 【第11周 项目1 - 二叉树算法验证(1)层次遍历算法的验证】
- 第11周项目1 -二叉树算法验证(1)层次遍历算法验证
- 第十一周实践项目1 - 二叉树算法验证(1)层次遍历算法的验证
- 第十一周实践项目1 - 二叉树算法验证(1)层次遍历算法的验证
- 第11周上机实践项目1- 二叉树算法验证(4)哈夫曼编码的算法验证
- 第十一周上机实践—项目1(1)—层次遍历算法的验证
- 第11周上机实践项目1—二叉树算法验证(3)中序线索化二叉树的算法验证
- 第11周项目1-验证算法(1)层次遍历算法的验证
- 第11周项目1 验证算法(1)层次遍历算法的验证
- 第11周 项目1-验证算法(1)层次遍历算法的验证
- 第11周 项目1-验证算法(1)层次遍历算法的验证
- 第11周项目1-验证算法(1)层次遍历算法的验证
- 第11周项目1 验证算法(1)层次遍历算法的验证
- 第11周—项目1(1)二叉树的层次遍历算法
- Python3.4(Pyhon)代码如何打包成.exe可执行文件——详细教程
- 多渠道打包和apk加密可以选用的工具
- PHP 如何获取当前的域名
- 第八周实践项目~顺序串算法
- 第11周上机实践项目1—二叉树算法验证(1)层次遍历算法的验证
- C++ 智能指针
- 流API--初体验
- 匿名内部类持外部引用造成内存泄漏问题
- CocoaPods详解之----使用篇
- Integer和String底层原理
- 请听一个故事------>寒门再难出贵子
- 封装jQuery Validate扩展验证方法
- 第十周项目2—二叉树遍历的递归算法