二叉树遍历实验报告

二叉树遍历实验报告
二叉树遍历实验报告

1.实验题目

二叉树的建立与遍历

[问题描述]

建立一棵二叉树,并对其进行遍历(先序、中序、后序),打印输出遍历结果。2.需求分析

(1)输入的形式和输入值的范围:以字符形式按先序遍历输入

(2)输出的形式:依次按递归先序、中序、后序遍历,非递归先序、中序、后序遍历结果输出

(3) 程序所能达到的功能:从键盘接受输入(先序)进行遍历(先序、中序、后序),将遍历结果打印输。

(4) 测试数据:

ABCффDEфGффFффф(其中ф表示空格字符)

则输出结果为先序:ABCDEGF

中序:CBEGDFA

后序:CGBFDBA

3.概要设计

(1)struct btnode{

char data; 数据

struct btnode *Lchild;左子数指针

struct btnode *Rchild; 右子数指针

};

struct btnode *createbt(struct btnode *bt )

初始条件:空二叉树存在

操作结果:先序建立二叉树

void preOrder(struct btnode *bt)

初始条件:二叉树存在

递归先序遍历二叉树

void preOrder1(struct btnode *bt)

初始条件:二叉树存在

操作结果:非递归先序遍历

void midOrder(struct btnode *bt)

初始条件:二叉树存在

操作结果:递归中序遍历

void midOrder1(struct btnode *bt)

初始条件:二叉树存在

操作结果:非递归中序遍历

void postOrder(struct btnode *bt)

初始条件:二叉树存在

操作结果:递归后序遍历

void postOrder1 (struct btnode *bt)

初始条件:二叉树存在

操作结果:非递归后序遍历

void main() 主函数

(2)void main() 主函数

{

*createbt

preOrder

preOrder1

midOrder

midOrder1

postOrder

postOrder1

}

4.详细设计

struct btnode{

char data;

struct btnode *Lchild;

struct btnode *Rchild;

};

struct btnode *createbt(struct btnode *bt ){ 输入结点数据c

检查存储空间

将c赋给结点参数p

递归建立左子树

递归建立右子树

}

void preOrder(struct btnode *bt){

判断树是否为空

输出根结点数data

递归遍历左子树

递归遍历右子树

}

void preOrder1(struct btnode *bt){

定义栈,结点参数p

While(栈或p是否为空){

While(p!=null){

输出根结点数data

将根结点压栈

遍历左子树

}

提取栈顶元素值

栈顶元素出栈

访问右子树

}

void midOrder(struct btnode *bt)

{判断树是否为空

递归遍历左子树

输出根结点数data

递归遍历右子树}

void midOrder1(struct btnode *bt){

定义栈,结点参数p

While(栈或p是否为空){

While(p!=null){

将根结点压栈

遍历左子树

}

提取栈顶元素值

输出根结点数data

栈顶元素出栈

访问右子树

}

void postOrder(struct btnode *bt){

判断树是否为空

递归遍历左子树

递归遍历右子树

输出根结点数data

}

void postOrder1 (struct btnode *bt){

定义栈,结点参数p,pre

bt入栈

While(栈或p是否为空){

提取栈顶元素值

if判断p是否为空或是pre的根结点

输出根结点数data

栈顶元素出栈

栈顶元素p赋给pre记录

else if右结点非空将右结点压栈

if左结点将左结点压栈}

}

void main(){

struct btnode *root=NULL;

root=createbt(root);

preOrder(root); midOrder(root); postOrder(root);

preOrder1(root); midOrder1(root);postOrder1(root);

}

5.调试分析

(1)先序建立二叉树时,虽用到递归建左右子树,但没有把他们赋值给根节点的左右指针,造成二叉树脱节。

(2)非递归后序遍历时,未考虑到所有条件,只考虑节点的左右结点是否为空,而未考虑结点是否是前一个遍历结点的根节点且不为空。

(3)用栈实现非递归遍历。

6.用户使用说明

运行环境为vc6.0

程序执行后在命令窗口中输入测试数据

然后enter

7.测试结果

8、附录

#include

#include

#include

#include

#include

using namespace std;

struct btnode{

char data;

struct btnode *Lchild;

struct btnode *Rchild;

};

struct btnode *createbt(struct btnode *bt )//先序建立二叉树

{

char c;

c=getchar();

if(c==' ')//如果输入为空,则子树为空

{

bt=NULL;

}

else

{

if(!(bt=(struct btnode *)malloc(sizeof(struct btnode))))//检验bt空间分配是否成功printf("error!");

bt->data=c;

bt->Lchild=createbt(bt->Lchild);//递归建立左子树

bt->Rchild=createbt(bt->Rchild); //递归建立右子树

}

return(bt);

}

void preOrder(struct btnode *bt)//递归先序遍历{

if(bt!=NULL)

{

printf("%c",bt->data);

preOrder(bt->Lchild);

preOrder(bt->Rchild);

}

}

void preOrder1(struct btnode *bt)//非递归先序遍历{

int i=0;

struct btnode *p;

stack s;定义栈

p=bt;

while(p!=NULL||!s.empty())

{

while(p!=NULL)

{

printf("%c",p->data);

s.push(p);//将根结点压栈

p=p->Lchild;//遍历左子树

}

if(!s.empty())

{

p=s.top();//提取栈顶元素值

s.pop();//栈顶元素出栈

p=p->Rchild;//访问右子树

}

}

}

void midOrder(struct btnode *bt)//递归中序遍历{

if(bt!=NULL)

{

midOrder(bt->Lchild);

printf("%c",bt->data);

midOrder(bt->Rchild);

}

void midOrder1(struct btnode *bt)//非递归中序遍历{

int i=0;

struct btnode *p;

stack s;

p=bt;

while(p!=NULL||!s.empty())

{

while(p!=NULL)

{

s.push(p);

p=p->Lchild;

}

if(!s.empty())

{

p=s.top();

printf("%c",p->data);

s.pop();

p=p->Rchild;

}

}

}

void postOrder(struct btnode *bt)//递归后序遍历{

if(bt!=NULL)

{

postOrder(bt->Lchild);

postOrder(bt->Rchild);

printf("%c",bt->data);

}

}

void postOrder1 (struct btnode *bt)//非递归后序遍历{

struct btnode *p,*pre=NULL;

stack s;

s.push(bt);

while(!s.empty())

{

p=s.top();

if((p->Lchild==NULL&&p->Rchild==NULL)||(pre!=NULL&&(pre==p->Lchild||pre==p-> Rchild)))//判断p是否为空或是pre的根结点

{

printf("%c",p->data);

s.pop();

pre=p;

}

else

{

if(p->Rchild!=NULL)

s.push(p->Rchild);//先将右结点压栈

if(p->Lchild!=NULL)

s.push(p->Lchild);//后将左结点压栈,因为先入后出

}

}

}

void main() //主函数

{

struct btnode *root=NULL;

root=createbt(root);

printf("先序递归遍历结果:");

preOrder(root);

printf("中序递归遍历结果:");

midOrder(root);

printf("后序递归遍历结果:");

postOrder(root);

printf("先序非递归遍历结果:");

preOrder1(root);

printf("中序非递归遍历结果:");

midOrder1(root);

printf("后序非递归遍历结果:");

postOrder1(root);

}

数据结构二叉树实验报告

实验三二叉树的遍历 一、实验目的 1、熟悉二叉树的结点类型和二叉树的基本操作。 2、掌握二叉树的前序、中序和后序遍历的算法。 3、加深对二叉树的理解,逐步培养解决实际问题的编程能力。 二、实验环境 运行C或VC++的微机。 三、实验内容 1、依次输入元素值,以链表方式建立二叉树,并输出结点的值。 2、分别以前序、中序和后序遍历二叉树的方式输出结点内容。 四、设计思路 1. 对于这道题,我的设计思路是先做好各个分部函数,然后在主函数中进行顺序排列,以此完成实验要求 2.二叉树采用动态数组 3.二叉树运用9个函数,主要有主函数、构建空二叉树函数、建立二叉树函数、访问节点函数、销毁二叉树函数、先序函数、中序函数、后序函数、范例函数,关键在于访问节点 五、程序代码 #include #include #include #define OK 1 #define ERROR 0 typedef struct TNode//结构体定义 {

int data; //数据域 struct TNode *lchild,*rchild; // 指针域包括左右孩子指针 }TNode,*Tree; void CreateT(Tree *T)//创建二叉树按,依次输入二叉树中结点的值 { int a; scanf("%d",&a); if(a==00) // 结点的值为空 *T=NULL; else // 结点的值不为空 { *T=(Tree)malloc(sizeof(TNode)); if(!T) { printf("分配空间失败!!TAT"); exit(ERROR); } (*T)->data=a; CreateT(&((*T)->lchild)); // 递归调用函数,构造左子树 CreateT(&((*T)->rchild)); // 递归调用函数,构造右子树 } } void InitT(Tree *T)//构建空二叉树 { T=NULL; } void DestroyT(Tree *T)//销毁二叉树 { if(*T) // 二叉树非空 { DestroyT(&((*T)->lchild)); // 递归调用函数,销毁左子树 DestroyT(&((*T)->rchild)); // 递归调用函数,销毁右子树 free(T); T=NULL; } } void visit(int e)//访问结点 { printf("%d ",e); }

二叉树实验报告

实验题目:实验九——二叉树实验 算法设计(3) 问题分析: 1、题目要求:编写算法交换二叉树中所有结点的左右子树 2、设计思路:首先定义一个二叉树的数据类型,使用先序遍历建立该二叉树,遍历二叉树,设计左右子树交换的函数,再次遍历交换之后的二叉树,与先前二叉树进行比较。遍历算法与交换算法使用递归设计更加简洁。 3、测试数据: A、输入:1 2 4 0 0 5 0 0 3 0 0 交换前中序遍历:4 2 5 1 3 交换后中序遍历:3 1 5 2 4 交换前:交换后: B、输入:3 7 11 0 0 18 17 0 0 19 0 0 6 13 0 0 16 0 0 交换前中序遍历:11 7 17 18 19 3 13 6 16 交换后中序遍历:16 6 13 3 19 18 17 7 11 概要设计: 1、为了实现上述功能:①构造一个空的二叉树;②应用先序遍历输入,建立二叉树;③中序遍历二叉树;④调用左右子树交换函数;⑤中序遍历交换过后的二叉树。 2、本程序包括4个函数: ①主函数main() ②先序遍历二叉树建立函数creat_bt() ③中序遍历二叉树函数inorder() ④左右子树交换函数 exchange()

各函数间关系如下: 详细设计: 1、结点类型 typedef struct binode //定义二叉树 { int data; //数据域 struct binode *lchild,*rchild; //左孩子、右孩子 }binode,*bitree; 2、各函数操作 ① 先序遍历建二叉树函数 bitree creat_bt() { 输入结点数据; 判断是否为0{ 若是,为空; 不是,递归;} 返回二叉树; } ② 左右子树交换函数 void exchange(bitree t) { 判断结点是否为空{ 否,交换左右子树; 递归;} } ③ 中序遍历函数 void inorder(bitree bt) { 判断是否为空{ 递归左子树; 输出; 递归右子树;} } main () creat_bt () inorder () exchange ()

二叉树的建立和遍历的实验报告doc

二叉树的建立和遍历的实验报告 篇一:二叉树的建立及遍历实验报告 实验三:二叉树的建立及遍历 【实验目的】 (1)掌握利用先序序列建立二叉树的二叉链表的过程。 (2)掌握二叉树的先序、中序和后序遍历算法。 【实验内容】 1. 编写程序,实现二叉树的建立,并实现先序、中序和后序遍历。 如:输入先序序列abc###de###,则建立如下图所示的二叉树。 并显示其先序序列为:abcde 中序序列为:cbaed 后序序列为:cbeda 【实验步骤】 1.打开VC++。 2.建立工程:点File->New,选Project标签,在列表中选Win32 Console Application,再在右边的框里为工程起好名字,选好路径,点OK->finish。至此工程建立完毕。 3.创建源文件或头文件:点File->New,选File标签,在列表里选C++ Source File。给文件起好名字,选好路径,点OK。至此一个源文件就被添加到了你刚创建的工程之中。

4.写好代码 5.编译->链接->调试 #include #include #define OK 1 #define OVERFLOW -2 typedef int Status; typedef char TElemType; typedef struct BiTNode { TElemType data; struct BiTNode *lchild, *rchild; }BiTNode,*BiTree; Status CreateBiTree(BiTree &T) { TElemType ch; scanf("%c",&ch); if (ch=='#') T= NULL; else { if (!(T = (BiTNode *)malloc(sizeof(BiTNode))))

二叉树基本操作+数据结构+实验报告

郑州轻工业学院数据结构实验报告 题目 学生姓名 学号 专业班级 完成时间 2016年月日

目录 一、系统功能介绍 (2) 二、需求分析 (2) 三、概要设计 (2) 四、详细设计 (5) 五、调试分析 (8) 六、使用说明 (8) 七、测试结果 (9) 八、心得体会 (10) 九、附录(程序代码) (11)

一、系统功能介绍 该系统主要功能是实现二叉树的定义和基本操作,包括定义二叉树的结构类型以及各个操作的具体函数的定义和主函数的定义。 各操作主要包括:初始化二叉树、按先序次序建立二叉树、检查二叉树是否为空、前序、中序、后序遍历树的方式、求树的深度、求树的结点数目、清空二叉树等九个对树的操作。 二、需求分析 本系统通过函数调用实现二叉树初始化,建立二叉树,检查树空与否,用前序、中序、后序遍历二叉树,求树的深度,求树的结点数目,清空二叉树等功能。 1)输出的形式和输出值的范围:在选择操作中,都以整型(数字)选择操作,插入和输出的数值都是char类型的字符; 2)输出的形式:在每次操作后,都会提示操作是否成功或者操作的结果; 3)程序达到的功能:完成初始化、检查是否为空、请空、遍历、求树的深度、求树的结点数目等功能; 4)测试数据设计: A,按先序次序建立二叉树。依次输入a,b,c,d,e,f,g.建立二叉树。 B,分别按先序,中序和后序遍历输出二叉树中的结点元素。 C,求树的高度和结点数。 三、概要分析 为了实现上述功能,定义二叉树的抽象数据类型。 ADT BinTree{ 数据对象D:D是具有相同特性的数据元素的集合。 数据关系R: 若D=¢,称BinTree为空二叉树 若D≠¢,则R={H},H是如下的二元关系; (1)在D中存在唯一的称为根的数据元素root,它在关系H下无前驱; (2)若D-{root}≠¢,则存在D-{root}={D1,Dr},且D1∩Dr=¢; (3)若D≠¢,则中存在唯一的元素x1,∈H,,且存在D1上的关系H1H;若则中存在唯一的元素且存在上的饿关系 (4)是一棵符合本定义的二叉树,称为根的左子树,是一棵符合本定义的二叉树,称为根的右子树。 基本操作 P:

二叉树的遍历算法实验报告

二叉树实验报告 09信管石旭琳 20091004418 一、实验目的: 1、理解二叉树的遍历算法及应用 2、理解哈夫曼树及其应用。 3、掌握哈夫曼编码思想。 二、实验内容: 1、建立二叉树二叉链表 2、实现二叉树递归遍历算法(中序、前序、后序) 3、求二叉树高度 4、求二叉树结点个数 5、求二叉树叶子个数 6、将序号为偶数的值赋给左子树 三、主要程序: #include #include typedef int ElemType; struct BiTNode { ElemType data; struct BiTNode *lch,*rch; }BiTNode,*BiTree; struct BiTNode *creat_bt1(); struct BiTNode *creat_bt2(); void preorder (struct BiTNode *t); void inorder (struct BiTNode *t); void postorder (struct BiTNode *t); void numbt (struct BiTNode *t); int n,n0,n1,n2; void main() { int k; printf("\n\n\n"); printf("\n\n 1.建立二叉树方法1(借助一维数组建立)"); printf("\n\n 2.建立二叉树方法2(先序递归遍历建立)"); printf("\n\n 3.先序递归遍历二叉树"); printf("\n\n 4.中序递归遍历二叉树"); printf("\n\n 5.后序递归遍历二叉树"); printf("\n\n 6.计算二叉树结点个数"); printf("\n\n 7.结束程序运行");

二叉树的遍历实验报告

二叉树的遍历实验报告 一、需求分析 在二叉树的应用中,常常要求在树中查找具有某种特征的结点,或者对树中全部结点逐一进行某种处理,这就是二叉树的遍历问题。 对二叉树的数据结构进行定义,建立一棵二叉树,然后进行各种实验操作。 二叉树是一个非线性结构,遍历时要先明确遍历的规则,先访问根结点还时先访问子树,然后先访问左子树还是先访问有右子树,这些要事先定好,因为采用不同的遍历规则会产生不同的结果。本次实验要实现先序、中序、后序三种遍历。 基于二叉树的递归定义,以及遍历规则,本次实验也采用的是先序遍历的规则进行建树的以及用递归的方式进行二叉树的遍历。 二、系统总框图

三、各模块设计分析 (1)建立二叉树结构 建立二叉树时,要先明确是按哪一种遍历规则输入,该二叉树是按你所输入的遍历规则来建立的。本实验用的是先序遍历的规则进行建树。 二叉树用链表存储来实现,因此要先定义一个二叉树链表存储结构。因此要先定义一个结构体。此结构体的每个结点都是由数据域data 、左指针域Lchild 、右指针域Rchild 组成,两个指针域分别指向该结点的左、右孩子,若某结点没有左孩子或者右孩子时,对应的指针域就为空。最后,还需要一个链表的头指针指向根结点。 要注意的是,第一步的时候一定要先定义一个结束标志符号,例如空格键、#等。当它遇到该标志时,就指向为空。 建立左右子树时,仍然是调用create ()函数,依此递归进行下去,

直到遇到结束标志时停止操作。 (2)输入二叉树元素 输入二叉树时,是按上面所确定的遍历规则输入的。最后,用一个返回值来表示所需要的结果。 (3)先序遍历二叉树 当二叉树为非空时,执行以下三个操作:访问根结点、先序遍历左子树、先序遍历右子树。 (4)中序遍历二叉树 当二叉树为非空时,程序执行以下三个操作:访问根结点、先序遍历左子树、先序遍历右子树。 (5)后序遍历二叉树 当二叉树为非空时,程序执行以下三个操作:访问根结点、先序遍历左子树、先序遍历右子树。 (6)主程序 需列出各个函数,然后进行函数调用。 四、各函数定义及说明 因为此二叉树是用链式存储结构存储的,所以定义一个结构体用以存储。 typedef struct BiTNode { char data; struct BiTNode *Lchild; struct BiTNode *Rchild;

二叉树的建立和遍历的实验报告

竭诚为您提供优质文档/双击可除二叉树的建立和遍历的实验报告 篇一:二叉树遍历实验报告 数据结构实验报告 报告题目:二叉树的基本操作学生班级: 学生姓名:学号: 一.实验目的 1、基本要求:深刻理解二叉树性质和各种存储结构的特点及适用范围;掌握用指针类型描述、访问和处理二叉树的运算;熟练掌握二叉树的遍历算法;。 2、较高要求:在遍历算法的基础上设计二叉树更复杂操作算法;认识哈夫曼树、哈夫曼编码的作用和意义;掌握树与森林的存储与便利。二.实验学时: 课内实验学时:3学时课外实验学时:6学时三.实验题目 1.以二叉链表为存储结构,实现二叉树的创建、遍历(实验类型:验证型)1)问题描述:在主程序中设计一个简单的菜单,分别调用相应的函数功能:1…建立树2…前序

遍历树3…中序遍历树4…后序遍历树5…求二叉树的高度6…求二叉树的叶子节点7…非递归中序遍历树0…结束2)实验要求:在程序中定义下述函数,并实现要求的函数功能:createbinTree(binTree structnode*lchild,*rchild; }binTnode;元素类型: intcreatebinTree(binTree voidpreorder(binTreevoidInorder(binTree voidpostorder(binTreevoidInordern(binTreeintleaf(bi nTree intpostTreeDepth(binTree 2、编写算法实现二叉树的非递归中序遍历和求二叉树高度。1)问题描述:实现二叉树的非递归中序遍历和求二叉树高度2)实验要求:以二叉链表作为存储结构 3)实现过程: 1、实现非递归中序遍历代码: voidcbiTree::Inordern(binTreeinttop=0;p=T;do{ while(p!=nuLL){ stack[top]=p;;top=top+1;p=p->lchild;}; if(top>0){ top=top-1;p=stack[top];

数据结构实验三——二叉树基本操作及运算实验报告

《数据结构与数据库》 实验报告 实验题目 二叉树的基本操作及运算 一、需要分析 问题描述: 实现二叉树(包括二叉排序树)的建立,并实现先序、中序、后序和按层次遍历,计算叶子结点数、树的深度、树的宽度,求树的非空子孙结点个数、度为2的结点数目、度为2的结点数目,以及二叉树常用运算。 问题分析: 二叉树树型结构是一类重要的非线性数据结构,对它的熟练掌握是学习数据结构的基本要求。由于二叉树的定义本身就是一种递归定义,所以二叉树的一些基本操作也可采用递归调用的方法。处理本问题,我觉得应该:

1、建立二叉树; 2、通过递归方法来遍历(先序、中序和后序)二叉树; 3、通过队列应用来实现对二叉树的层次遍历; 4、借用递归方法对二叉树进行一些基本操作,如:求叶子数、树的深度宽度等; 5、运用广义表对二叉树进行广义表形式的打印。 算法规定: 输入形式:为了方便操作,规定二叉树的元素类型都为字符型,允许各种字符类型的输入,没有元素的结点以空格输入表示,并且本实验是以先序顺序输入的。 输出形式:通过先序、中序和后序遍历的方法对树的各字符型元素进行遍历打印,再以广义表形式进行打印。对二叉树的一些运算结果以整型输出。 程序功能:实现对二叉树的先序、中序和后序遍历,层次遍历。计算叶子结点数、树的深度、树的宽度,求树的非空子孙结点个数、度为2的结点数目、度为2的结点数目。对二叉树的某个元素进行查找,对二叉树的某个结点进行删除。 测试数据:输入一:ABC□□DE□G□□F□□□(以□表示空格),查找5,删除E 预测结果:先序遍历ABCDEGF 中序遍历CBEGDFA 后序遍历CGEFDBA 层次遍历ABCDEFG 广义表打印A(B(C,D(E(,G),F))) 叶子数3 深度5 宽度2 非空子孙数6 度为2的数目2 度为1的数目2 查找5,成功,查找的元素为E 删除E后,以广义表形式打印A(B(C,D(,F))) 输入二:ABD□□EH□□□CF□G□□□(以□表示空格),查找10,删除B 预测结果:先序遍历ABDEHCFG 中序遍历DBHEAGFC 后序遍历DHEBGFCA 层次遍历ABCDEFHG 广义表打印A(B(D,E(H)),C(F(,G))) 叶子数3 深度4 宽度3 非空子孙数7 度为2的数目2 度为1的数目3 查找10,失败。

二叉树实验报告

二叉树的创建与遍历 一、试验内容 根据输入的字符串创建树或二叉树,输出树或二叉树的先序遍历和后序遍历序列。 二、运行环境 Visual C++ 三、需求分析 1、建立一棵用二叉链表方式存储的二叉树。 2、从键盘接受扩展先序序列,以二叉链表作为存储结构。 3、建立二叉树,并将遍历结果打印输出。采用递归和非递归两种 方法实现。 四、设计概要 //——————二叉树的二叉链表存储表示—————— typedef struct BiTBode{ TElemType data; Struct BiTNode *lchild, *rchild //左右孩子指针 }BiTNode, *BiTree; //—————基本操作的函数原型说明———————— Status CreateBiTree(BiTree &T); //按先序次序输入二叉树中结点的值(一个字符),空格字符表示空树。 //构造二叉树链表表示的二叉树T。 Status PreOrderTraverse(BiTree T, status(*visit)(TElemType e)); //采用二叉链表存储结构,visit是对结点操作的应用函数。 //先序遍历二叉树T,对每个结点调用函数visit一次且仅以次。 //一旦visit()失败,则操作失败。 Status PostOrderTraverse(BiTree T, status(*visit)(TElemType e)); //采用二叉链表存储结构,visit是对结点操作的应用函数。 //后序遍历二叉树T,对每个结点调用函数visit一次且仅以次。 //一旦visit()失败,则操作失败。 —————先序遍历二叉树基本操作的递归算法———— Status PreOrderTraverse(BiTree T,Status(*visit)(TElemType e)){ //采用二叉链表存储结构,visit是对数据元素操作的应用函数,

数据结构二叉树遍历实验报告

问题一:二叉树遍历 1.问题描述 设输入该二叉树的前序序列为: ABC##DE#G##F##HI##J#K##(#代表空子树) 请编程完成下列任务: ⑴请根据此输入来建立该二叉树,并输出该二叉树的前序、中序和后序序列; ⑵按层次遍历的方法来输出该二叉树按层次遍历的序列; ⑶求该二叉树的高度。 2.设计描述 (1)二叉树是一种树形结构,遍历就是要让树中的所有节点被且仅被访问一次,即按一定规律排列成一个线性队列。二叉(子)树是一种递归定义的结构,包含三个部分:根结点(N)、左子树(L)、右子树(R)。根据这三个部分的访问次序对二叉树的遍历进行分类,总共有6种遍历方案:NLR、LNR、LRN、NRL、RNL和LNR。研究二叉树的遍历就是研究这6种具体的遍历方案,显然根据简单的对称性,左子树和右子树的遍历可互换,即NLR与NRL、LNR与RNL、LRN 与RLN,分别相类似,因而只需研究NLR、LNR和LRN三种即可,分别称为“先序遍历”、“中序遍历”和“后序遍历”。采用递归方式就可以容易的实现二叉树的遍历,算法简单且直观。 (2)此外,二叉树的层次遍历即按照二叉树的层次结构进行遍历,按照从上到下,同一层从左到右的次序访问各节点。遍历算法可以利用队列来实现,开始时将整个树的根节点入队,然后每从队列中删除一个节点并输出该节点的值时,都将它的非空的左右子树入队,当队列结束时算法结束。

(3)计算二叉树高度也是利用递归来实现:若一颗二叉树为空,则它的深度为0,否则深度等于左右子树的最大深度加一。 3.源程序 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #include #include #include #define ElemType char struct BTreeNode { ElemType data; struct BTreeNode* left; struct BTreeNode* right; }; void CreateBTree(struct BTreeNode** T) { char ch; scanf_s("\n%c", &ch); if (ch == '#') *T = NULL;

二叉树实验报告

题目: 编程实现二叉查找树的建立、中序遍历、元素查找等功能,要求解释实现过程及演示实际例子的运行结果。 算法描述: 首先创建二叉树结点类,其主要包括:二叉树结点数据域,指向左、右子树的指针,构造函数,设置当前结点左、右子树、数据域以及判断当前结点是否为叶子结点等。然后进行二叉树类定义,其私有部分为定义二叉树根结点指针,公有部分主要包括:构造函数、析构函数、判断二叉树是否为空树、先,中,后序遍历的递归与非递归、二叉树删除、层序遍历以及二叉树搜索等。接下来将对一些重要函数算法进行描述: 1、isLeaf函数:若该结点的左子树和右子树都为空,则为叶子结点。 2、isEmpty函数:根结点为空则为空树。 3、Parent函数:首先判断给定结点是否有双亲,根结点和空结点一定无双亲,初始化一个临时变量,用于跟进查找双亲结点,查找到后其保存的便是双亲结点。先递归在左子树中查找,如果找到,便结束递归且返回双亲结点指针;如果没有找到,再递归在右子树中查找。如果都没有找到,说明给定结点的双亲结点不在该二叉树中。 4、LeftSibling(RightSibling)函数:首先找到当前结点的双亲,然后判断双亲结点左右子树是否为空,其中必然有一个不为空,返回另一个子树指针即可。 5、DeleteBinaryTree函数:首先判断是否为空树,若为空,则返回,然后递归删除左子树,递归删除右子树,最后删除根结点。 6、PreOrder函数:首先判断是否为空树,若为空,则返回,然后访问根结点,递归遍历左子树,递归遍历右子树,结束。 7、PreOrderWithoutRecusion函数:使用栈来模拟递归过程,首先申请栈,用于保存结点指针序列,申请指针pointer保存当前根指针,然后判断栈是否为空,若栈为空且pointer为空,跳出函数,否则若pointer不为空,访问pointer所指结点,pointer入栈,pointer指向其左子树;若pointer为空,弹出栈顶元素赋给pointer,pointer指向其右子树,结束。 8、CreateTree函数:采用先序遍历序列构造二叉树,设‘0’为空结点,输入非‘0’数,生成新结点,递归创建左子树和右子树。 9、Search函数:采用先序遍历查找给定元素是否在二叉树中,首先判断树是否是空树,若是空树,则返回空指针。然后初始化临时指针temp,查找成功后temp即为所给元素所在

二叉树的建立和遍历实验报告

实验四二叉树的建立和遍历 学院专业班 学号姓名 一.实习目的 1.掌握二叉链表的存储结构; 2.掌握二叉链表的建立; 3.掌握二叉树的先序遍历、中序遍历、后序遍历的递归算法; 4. 掌握二叉树遍历算法的应用; 二.实习内容 1.按先序序列建立二叉树的二叉链表(算法6.4)(空树用#表示) 2.对生成的二叉树分别进行先序遍历、中序遍历、后序遍历,输出结果。 3.统计二叉树中结点个数; 4. 求二叉树的高度; 三.实验步骤 1.定义二叉链表的存储结构 #include "stdio.h" #include "stdlib.h" typedef char TElemType; typedef struct BiTNode { TElemType data; struct BiTNode *lchild, *rchild; // 左右孩子指针 }BiTNode,*BiTree; 2.编写函数CreateBiTree,按先序序列建立二叉树的二叉链表; 测试的字符序列为abdg###e##c#f##; 程序代码为: void CreateBiTree(BiTree &T) { // 算法6.4:按先序次序输入二叉树中结点的值(可为字符型或整型,在主程中定义),构造二叉链表表示的二叉树T。以#表示空树 TElemType ch; scanf("%c",&ch); if(ch=='#') // 空 T=NULL; else { T=(BiTree )malloc(sizeof(BiTNode)); // 生成根结点 if(!T)

exit(-1); T->data=ch; CreateBiTree(T->lchild);// 递归构造左子树 CreateBiTree(T->rchild);// 构造右子树 } } 2. 编写二叉树的先序遍历、中序遍历、后序遍历的递归算法 int preOrderTraverse(BiTree T) { // 初始条件:二叉树T存在,先序递归遍历T; if(T==NULL) return 1; if(T!=NULL) // T不空 {printf("%5c",T->data); // 访问根结点preOrderTraverse(T->lchild);// 先序遍历左子树 preOrderTraverse(T->rchild);// 先序遍历右子树 } } int inOrderTraverse(BiTree T) { // 初始条件:二叉树T存在,中序递归遍历T; if(T==NULL) return 1; if(T!=NULL) // T不空 { inOrderTraverse(T->lchild);// 中序遍历左子树 printf("%5c",T->data); // 访问根结点inOrderTraverse(T->rchild);// 中序遍历右子树 } } int postOrderTraverse(BiTree T) { // 初始条件:二叉树T存在, // 操作结果:后序递归遍历T; if(T==NULL) return 1; if(T!=NULL) // T不空 { postOrderTraverse(T->lchild);// 后序遍历左子树 postOrderTraverse(T->rchild);// 后序遍历右子树 printf("%5c",T->data); // 访问根结点

数据结构实验报告—二叉树

算法与数据结构》课程实验报告

一、实验目的 1、实现二叉树的存储结构 2、熟悉二叉树基本术语的含义 3、掌握二叉树相关操作的具体实现方法 二、实验内容及要求 1. 建立二叉树 2. 计算结点所在的层次 3. 统计结点数量和叶结点数量 4. 计算二叉树的高度 5. 计算结点的度 6. 找结点的双亲和子女 7. 二叉树前序、中序、后序遍历的递归实现和非递归实现及层次遍历 8. 二叉树的复制 9. 二叉树的输出等 三、系统分析 (1)数据方面:该二叉树数据元素采用字符char 型,并且约定“ #”作为二叉树输入结束标识符。并在此基础上进行二叉树相关操作。 (2)功能方面:能够实现二叉树的一些基本操作,主要包括: 1. 采用广义表建立二叉树。 2. 计算二叉树高度、统计结点数量、叶节点数量、计算每个结点的度、结点所在层次。 3. 判断结点是否存在二叉树中。 4. 寻找结点父结点、子女结点。 5. 递归、非递归两种方式输出二叉树前序、中序、后序遍历。 6. 进行二叉树的复制。 四、系统设计 (1)设计的主要思路 二叉树是的结点是一个有限集合,该集合或者为空,或者是由一个根节点加上两棵分别称为左子树和右子树、互不相交的二叉树组成。根据实验要求,以及课上老师对于二叉树存储结构、基本应用的讲解,同时课后研究书中涉及二叉树代码完成二叉树模板类,并将所需实现各个功能代码编写完成,在建立菜单对功能进行调试。 (2)数据结构的设计 二叉树的存储结构有数组方式和链表方式。但用数组来存储二叉树有可能会消耗大量的存储空间,故在此选用链表存储,提高存储空间的利用率。根据二叉树的定义,二叉

二叉树的遍历及线索化

青岛理工大学数据结构课程实验报告

void PreOrderTraverse(BiTree T,Status(*Visit)(TElemType e)){ if(T){ Visit(T->data);//首先访问根结点 PreOrderTraverse(T->lchild,Visit);//然后递归遍历左子树 PreOrderTraverse(T->rchild,Visit);//最后递归遍历右子树}} //中序遍历时先递归遍历左子树,然后访问根结点,最后递归遍历右子树;后序遍历时先递归遍历左子树,然后递归遍历右子树,最后 访问根结点 3、//先把栈及队列相关操作的头文件包括进来 1)根指针入栈, 2)向左走到左尽头(入栈操作) 3)出栈,访问结点 4)向右走一步,入栈,循环到第二步,直到栈空 //层次遍历时,若树不空,则首先访问根结点,然后,依照其双亲结 点访问的顺序,依次访问它们的左、右孩子结点; 4.首先建立二叉线索存储:包含数据域,左右孩子指针以及左右标志 typedef enum { Link=0,Thread=1 } PointerTag; typedef struct BiThrNode{ TElemType data; struct BiThrNode *lchild,*rchild;//左右孩子指针 PointerTag LTag,RTag;//左右标志 }BiThrNode, *BiThrTree; 建立前驱线索和后继线索,并用中序遍历进行中序线索化,然后最 后一个结点线索化 调 试 过 程 及 实 验 结 果 把测试数据放在f:\\file\\data.txt里,测试数据为:1 2 4 0 0 0 3 5 0 0 0 总访问结点是指访问该结点的数据域,弄清楚各个指针所指的类型

数据结构遍历二叉树实验报告

太原师范学院 实验报告Experimentation Report of Taiyuan Normal University 系部计算机系年级XX 课程数据结构 姓名XXX 同组者日期 项目二叉树的遍历 一、实验目的: ①设计程序分别实现实现对二叉树的先序、中序、后序遍历。 ②计算出二叉树的节点个数、叶子节点个数、二叉树的深度等。 二、实验要求: ①掌握先序、中序、后序遍历二叉树的过程。 ②掌握二叉树的先序、中序、后序遍历算法。 三、实验平台 硬件:笔记本电脑一台; 软件:Windows 10,visual_studio_2010; 四、运行结果(运行界面图及说明) 测试数据:ABC##DE#G##F### -*a##b##c##

五、实验体会 1.上机多加练习才能真正学会相关内容; 2.应对二叉树的性质熟练掌握; 3.实验错误太多,应加强基础知识的学习。 六、附完整代码 #include using namespace std; #include #include #include #define OK 1 #define ERROR 0 #define OVERFLOW -2 typedef int Status; typedef int TElemType; #define MAXSIZE 100 typedef struct BiTNode{ TElemType data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; void CreateBiTree(BiTree &T) {char ch; cin>>ch; if(ch=='#') T=NULL; else { T=new BiTNode; T->data=ch; CreateBiTree(T->lchild); CreateBiTree(T->rchild); } } void InOrderaTraverse(BiTree T)

数据结构二叉树的实验报告

数据结构 实 验 报 告

1. 实验目的和内容: 掌握二叉树基本操作的实现方法2. 程序分析 2.1存储结构 链式存储 2.程序流程

2.3关键算法分析 算法一:Create(BiNode* &R,T data[],int i,int n) 【1】算法功能:创建二叉树 【2】算法基本思想:利用顺序存储结构为输入,采用先建立根结点,再建立左右孩子的方法来递归建立二叉链表的二叉树 【3】算法空间时间复杂度分析:O(n) 【4】代码逻辑: 如果位置小于数组的长度则 {创建根结点 将数组的值赋给刚才创建的结点的数据域 创建左子树,如果当前结点位置为i,则左孩子位置为2i 创建右子树,如果当前结点位置为i,则右孩子位置为2i+1 } 否则R为空 算法二:CopyTree(BiNode*sR,BiNode* &dR) ) 【1】算法功能:复制构造函数 【2】算法基本思想:按照先创建根结点,再递归创建左右子树的方法来实现。 【3】算法空间时间复杂度分析:O(n) 【4】代码逻辑: 如果源二叉树根结点不为空 则{ 创建根结点 调用函数自身,创建左子树 调用函数自身,创建右子树 } 将该函数放在复制构造函数中调用,就可以实现复制构造函数

算法三:PreOrder(BiNode*R) 【1】算法功能:二叉树的前序遍历 【2】算法基本思想:这个代码用的是优化算法,提前让当前结点出栈。【3】算法空间时间复杂度分析:O(n) 【4】代码逻辑(伪代码) 如果当前结点为非空,则 { 访问当前结点 当前结点入栈 将当前结点的左孩子作为当前结点} 如果为空 { 则栈顶结点出栈 则将该结点的右孩子作为当前结点 } 反复执行这两个过程,直到结点为空并且栈空 算法四:InOrder(BiNode*R) 【1】算法功能:二叉树的中序遍历 【2】算法基本思想:递归 【3】算法空间时间复杂度分析:未知 【4】代码逻辑: 如果R为非空: 则调用函数自身遍历左孩子 访问该结点 再调用自身访问该结点的右孩子 算法五:LevelOrder(BiNode*R) 【1】算法功能:二叉树的层序遍历 【2】算法基本思想: 【3】算法空间时间复杂度分析:O(n) 【4】代码逻辑(伪代码): 若根结点非空,入队

数据结构 二叉树遍历实验报告

数据结构之二叉树 实验报告 题目:二叉树的遍历和子树交换 指导老师:杨政宇 班级:通信1202 姓名:徐江 学号:0909121127

需求分析 1.演示程序分别用多种遍历算法遍历二叉树并把数据输出。 2.输入字符序列,递归方式建立二叉树。 3.在演示过程序中,用户敲击键盘,输入数据,即可看到数据的输出。 4.实现链式存储的二叉树的多种遍历算法。 遍历算法包括: a)中序递归遍历算法、前序递归遍历算法【选】 b)中序遍历非递归算法 c)先序或后序遍历非递归算法 d)建立中序线索,并进行中序遍历和反中序遍历 5.实现二叉树的按层遍历算法 6.设计一个测试用的二叉树并创建对应的内存二叉树,能够测试自己算法的边界(包括树节点数为0、1以及>1 的不同情形)。 7.测试数据:输入数据:-+a *b -c d -e f 概要设计 说明:本程序在递归调用中用到了链表,在非递归调用时用到了栈。 1.栈的抽象数据类型 ADT Stack{ 数据对象:D={a i|a i∈char,i=1,2,3……..} 数据关系:R={< a i-1,a i >| a i-1,a i∈D,i=2,3…..} 基本操作: InitStack(&S) 操作结果:构造一个空栈 StackEmpty( S ) 初始条件:栈S已存在。 操作结果:若S为空栈,则返回OK,否则返回ERROR。 Push( &S, e ) 初始条件:栈S已存在。 操作结果:插入元素e为新的栈顶元素。 Pop( &S, &e ) 初始条件:栈S已存在且非空。 操作结果:删除S的栈顶元素,并用e返回其值。 GetTop( S, &e ) 初始条件:栈S已存在且非空。 操作结果:用e返回S的栈顶元素。 }

二叉树基本操作--实验报告

实验三 二叉树的基本操作 学院:物理与电子学院 班级:电信1105班 :岩 学号:1404110729

一、实验目的 1、熟悉二叉树的基本操作,掌握二叉树的实现以及实际应用。 3、加深对于二叉树的理解,逐步培养解决实际问题的编程能力。 二、实验环境 1台WINDOWS环境的PC机,装有Visual C++ 6.0。 三、实验容 1、问题描述 现需要编写一套二叉树的操作函数,以便用户能够方便的利用这些函数来实现自己的应用。其中操作函数包括: 1>创建二叉树CreateBTNode(*b,*str):根据二叉树括号表示法的字符串*str生成对应的 链式存储结构。 2>输出二叉树DispBTNode(*b):以括号表示法输出一棵二叉树。 3>查找结点FindNode(*b,x):在二叉树b中寻找data域值为x的结点,并返回指向该结 点的指针。 4>求高度BTNodeDepth(*b):求二叉树b的高度。若二叉树为空,则其高度为0;否则,其 高度等于左子树与右子树中的最大高度加l。 5>求二叉树的结点个数NodesCount(BTNode *b) 6>先序遍历的递归算法:void PreOrder(BTNode *b) 7>中序遍历的递归算法:void InOrder(BTNode *b) 8>后序遍历递归算法:void PostOrder(BTNode *b) 9>层次遍历算法void LevelOrder(BTNode *b) 2、基本要求 实现以上9个函数。 主函数中实现以下功能: 创建下图中的树b 输出二叉树b 找到’H’节点,输出其左右孩子值 输出b的高度 输出b的节点个数 输出b的四种遍历顺序

实验10 二叉树的基本操作

浙江大学城市学院实验报告 课程名称数据结构基础 实验项目名称实验十二叉树的基本操作 学生姓名专业班级学号 实验成绩指导老师(签名)日期2014-12-18 一.实验目的和要求 1、掌握二叉树的链式存储结构。 2、掌握在二叉链表上的二叉树操作的实现原理与方法。 3、进一步掌握递归算法的设计方法。 二.实验内容 1、按照下面二叉树二叉链表的存储表示,编写头文件binary_tree.h,实现二叉链表的定义与基本操作实现函数;编写主函数文件test4_1.cpp,验证头文件中各个操作。 二叉树二叉链表存储表示如下: struct BTreeNode { ElemType data; // 结点值域 BTreeNode *lchild , *rchild ; // 定义左右孩子指针 } ; 基本操作如下: ①void InitBTree( BTreeNode *&BT ); //初始化二叉树BT ②void CreateBTree( BTreeNode *&BT, char *a ); //根据字符串a所给出的广义表表示的二叉树建立二叉链表存储结构 ③int EmptyBTree( BTreeNode *BT); //检查二叉树BT是否为空,空返回1,否则返回0 ④int DepthBTree( BTreeNode *BT); //求二叉树BT的深度并返回该值 ⑤int FindBTree( BTreeNode *BT, ElemType x); //查找二叉树BT中值为x的结点,若查找成功返回1,否则返回0 ⑥void PreOrder( BTreeNode *BT); //先序遍历二叉树BT ⑦void InOrder( BTreeNode *BT); //中序遍历二叉树BT ⑧void PostOrder( BTreeNode *BT); //后序遍历二叉树BT

数据结构实验报告二叉树

《数据结构与算法》实验报告 专业班级姓名学号 实验项目 实验三二叉树。 实验目的 1、掌握用递归方法实现二叉树的遍历。 2、加深对二叉树的理解,逐步培养解决实际问题的编程能力。 题目: (1)编写二叉树的遍历操作函数。 ①先序遍历,递归方法re_preOrder(TREE *tree) ②中序遍历,递归方法re_midOrder(TREE *tree) ③后序遍历,递归方法re_postOrder(TREE *tree) (2)调用上述函数实现先序、中序和后序遍历二叉树操作。 算法设计分析 (一)数据结构的定义 要求用c语言编写一个演示程序,首先建立一个二叉树,让用户输入一个二叉树,实现该二叉树的便利操作。 二叉树型存储结构定义为: typedef struct TNode { char data;//字符型数据 struct TNode *lchild,*rchild;//左右孩子指针 }TNode,* Tree; (二)总体设计 程序由主函数、二叉树建立函数、先序遍历函数、中序遍历函数、后序遍历函数五个函数组成。其功能描述如下: (1)主函数:统筹调用各个函数以实现相应功能。 int main() (2)二叉树建立函数:根据用户意愿运用先序遍历建立一个二叉树。 int CreateBiTree(Tree &T) (3)先序遍历函数:将所建立的二叉树先序遍历输出。 void PreOrder(Tree T) (4)中序遍历函数:将所建立的二叉树中序遍历输出。 void InOrder(Tree T) (5)后序遍历函数:将所建立的二叉树后序遍历输出。 void PostOrder(Tree T)

二叉树实验报告

二叉树实验报告 问题描述 (1)问题描述:①用先序递归过程建立二叉树 (存储结构:二叉链表)。 输入数据按先序遍历所得序列输入,当某结点左子树或右子树为空时,输入‘*’号,如输入abc**d**e**得到的二叉树为: ②编写递归算法,计算二叉树中叶子结点的数目。 ③按凹入表方式输出该二叉树。 (2)分析:①此题要求用二叉链表作为存储结构,首先要定义二叉链表: typedef struct BiTNode { char data; struct BiTNode *lchild, *rchild; }BiTNode, * BiTree; struct BiTNode *lchild, *rchild 中lchild ,rchild 分别表示该结点的左右孩子。 ②输入时,按先序遍历所得序列输入,当某结点左子树或右子树为空时,输入‘*’号。 ③输出以凹入表的形式输出。 算法思想 (1)按照要求,这道题采用二叉链表来存储矩阵的有关信息。 存储结构定义为: typedef struct BiTNode { char data; struct BiTNode *lchild, *rchild; }BiTNode, * BiTree; 题中共有四个函数,包括主函数main(),创建二叉树函数Status preorder(BiTree &T),计算叶子结点函数Status calLeaf(BiTree &T),输出函数Status output(BiTree &T,int)。其中,主函数首先调用preorder()创建二叉树,然后调用函数calLeaf()。最后调用函数output(),输出二叉树。 (2)算法描述: a b e c d

相关文档
最新文档