二叉树遍历算法的应用与实现数据结构课程设计说明书格式_第1页
二叉树遍历算法的应用与实现数据结构课程设计说明书格式_第2页
二叉树遍历算法的应用与实现数据结构课程设计说明书格式_第3页
二叉树遍历算法的应用与实现数据结构课程设计说明书格式_第4页
二叉树遍历算法的应用与实现数据结构课程设计说明书格式_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、中北大学数 据 结 构课 程 设 计 说 明 书学生姓名:宁亚楠学 号:1021011601学 院:软件学院专 业:软件开发与测试题 目:二叉树遍历算法的应用与实现指导教师何志英2011年12月20日1. 设计任务概述(包括系统总体框图及功能描述)此次课程设计遍历算法的框架图遍历算法递归遍历非递归遍历先序遍历中序遍历后序遍历先序遍历中序遍历后序遍历 此次课程设计所用二叉树 abdcfe2. 本设计所采用的数据结构(如:链表、栈、树、图等)链表,栈,二叉树。3. 功能模块详细设计 本程序的功能是建立二叉树,对二叉树进行递归先序遍历、中序遍历和后序遍历,用栈实现非递归的先序、中序遍历和后序遍历。

2、本程序要求用户以字符输入,最后以回车键建入数据。本程序的结果将依次打印出递归先序遍历、中序遍历和后序遍历,用栈实现非递归的先序和中序遍历和后序遍历。3.1 详细设计思想函数功能及声明如下,源代码见附表: int createbitree(bitree *t); /建立一棵二叉树 int preorder(bitree t); /先序递归遍历二叉树 int inorder(bitree t); /中序递归遍历二叉树 int oldorder(bitree t); /后序递归遍历二叉树 void dlr(bitnode *t); /前序非递归遍历二叉树 void ldr(bitnode *t);

3、/中序非递归遍历二叉树 void lrd(bitnode *t); /后序非递归遍历二叉树 void main();/选择功能及输出界面3.2 核心代码#include#include#define maxsize 100int leafcount=0;/二叉树的二叉链表存储表示typedef struct bitnode char data; struct bitnode *lchild,*rchild;bitnode,*bitree;/栈的定义typedef struct stack int top; bitree stacklistmaxsize;stack,*sqlist; /构造一棵

4、二叉树int createbitree(bitree *t) char ch;printf(输入节点:n); scanf(%c,&ch);ch=getchar();while(!(ch=a|ch=0)|(ch=a|ch=0)/printf(字符非法,请重新输入n);ch=getchar();printf(n); if(ch=0) *t=null; else if(!(*t=(bitree)malloc(sizeof(bitnode) return 0; (*t)-data=ch; createbitree(&(*t)-lchild); createbitree(&(*t)-rchild); r

5、eturn 1;/先序递归遍历二叉树int preorder(bitree t) if(t) printf(%c ,t-data); if (!t-lchild&!t-rchild) leafcount+=1; preorder(t-lchild); preorder(t-rchild); return 1;/中序递归遍历二叉树int inorder(bitree t) if(t) inorder(t-lchild); printf(%c ,t-data); inorder(t-rchild); return 1;/后序递归遍历二叉树int oldorder(bitree t) if(t) o

6、ldorder(t-lchild); oldorder(t-rchild); printf(%c ,t-data); return 1;/先序非递归遍历二叉树void dlr(bitnode *t) stack s; bitree p; int top; top=0; if(t) p=t; while(p|top0) if(p) s.stacklisttop+=p; printf(%c ,p-data); p=p-lchild; else p=s.stacklist-top; p=p-rchild; /中序非递归遍历二叉树void ldr(bitnode *t) stack s; bitree

7、 p; int top; top =0; if(t) p=t; while(top=0) if(p!=null) s.stacklisttop+=p; p=p-lchild; else if(top=0) break; p=s.stacklist-top; printf(%c ,p-data); p=p-rchild; /后序非递归遍历二叉树void lrd(bitnode *t) stack s; bitree p; bitree ti; bitree last=0; int top; p=t; ti=t; top=0; while(p!=0)|(top0) while(p) s.stack

8、listtop+=p; p=p-lchild; ti=s.stacklisttop-1; if(ti-rchild=null|ti-rchild=last) printf(%c ,ti-data); last=s.stacklist-top; else p=ti-rchild; void main() bitree t; leafcount=0; printf(/t/n/n请读入字符 :n); createbitree(&t); printf(tnn递归先序遍历序列为:); preorder(t); printf(tnn递归中序遍历序列为:); inorder(t); printf(tnn递归

9、后序遍历序列为:); oldorder(t); printf(tnn非递归先序遍历序列为:); dlr(t); printf(tnn非递归中序遍历序列为:); ldr(t); printf(tnn非递归后序遍历序列为:) ; lrd(t); printf(tnn叶子节点:%d n,leafcount); system(pause); 3.3 程序运行结果(拷屏)a) 进入初始输入界面:b) 输入节点字符: c) 六种遍历方法结果输出:4. 课程设计心得、存在问题及解决方法这个程序的代码较为简单,可以实现了二叉树的三种递归遍历算法和三种非递归遍历算法,想要改进的话可以在选择功能上下手,建立的时候提示更人性化,对输入的数据进行有效性验证,也可以改进为对遍历算法进行选择等等。二叉树这个数据结构几乎在每一本的数据结构的书都作为重点内容讲述,足见其在算法和程序设计界的重要地位。但是,到目前为止,自己还没有真正体验到它的威力,可能是学习的还不够深刻。像二叉树遍历的算法,用递归的算法只是简单的几行代码,然后就可以实现输出遍历次序。对于非递归的思想,要用到栈这个数据结构,但是对于二叉树遍历问题来说非递归要较递归复杂。程序一开始总是出现语法错误,改了很多次也请教了大三的学长才最后改为现在可以成功运行的程序。在这个

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论