数据结构课程设计_二叉排序树的实现

数据结构课程设计_二叉排序树的实现

ID:16032014

大小:85.50 KB

页数:12页

时间:2018-08-07

数据结构课程设计_二叉排序树的实现_第1页
数据结构课程设计_二叉排序树的实现_第2页
数据结构课程设计_二叉排序树的实现_第3页
数据结构课程设计_二叉排序树的实现_第4页
数据结构课程设计_二叉排序树的实现_第5页
资源描述:

《数据结构课程设计_二叉排序树的实现》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、数据结构课程设计数据结构课程设计一、引言数据结构是一门理论性强、思维抽象、难度较大的课程,是基础课和专业课之间的桥梁。该课程的先行课程是计算机基础、程序设计语言、离散数学等,后续课程有操作系统、编译原理、数据库原理、软件工程等。通过本门课程的学习,我们应该能透彻地理解各种数据对象的特点,学会数据的组织方法和实现方法,并进一步培养良好的程序设计能力和解决实际问题的能力。数据结构是计算机科学与技术专业的一门核心专业基础课程,在该专业的课程体系中起着承上启下的作用,学好数据结构对于提高理论认知水平和实践能

2、力有着极为重要的作用。学习数据结构的最终目的是为了获得求解问题的能力。对于现实世界中的问题,应该能从中抽象出一个适当的数学模型,该数学模型在计算机内部用相应的数据结构来表示,然后设计一个解此数学模型的算法,再进行编程调试,最后获得问题的解答。实习课程是为了加强编程能力的培养,鼓励学生使用新兴的编程语言。相信通过数据结构课程实践,无论是理论知识,还是实践动手能力,我们都会有不同程度上的提高。二、课程设计目的本课程是数据结构课程的实践环节。主要目的在于加强学生在课程中学习的相关算法和这些方法的具体应用,

3、使学生进一步掌握在C++或其他语言中应用这些算法的能力。通过课程设计题目的练习,强化学生对所学知识的掌握及对问题分析和任务定义的理解。第12页共12页数据结构课程设计三、内容设计要求二叉排序树的实现:用顺序和二叉链表作存储结构1)以回车(‘’)为输入结束标志,输入数列L,生成一棵二叉排序树T;2)对二叉排序树T作中序遍历,输出结果;3)输入元素x,查找二叉排序树T,若存在含x的结点,则删除该结点,并作中序遍历(执行操作2);否则输出信息“无x”。(一)问题分析和任务定义对问题的描述应避开具体的算

4、法和涉及的数据结构,它是对要完成的任务作出明确的回答,强调的是做什么,而不是怎么做。(二)详细的设计和编码算法的具体描述和代码的书写。(三)上机调试源程序的输入和代码的调试。要求:设计中要求综合运用所学知识,上机解决一些与实际应用结合紧密的、规模较大的问题,通过分析、设计、编码、调试等各环节的训练,深刻理解、牢固的掌握数据结构和算法设计技术,掌握分析、解决实际问题的能力。四、源代码1、用二叉链表存储结构实现#includeusingnamespacestd;第12页共12页数据结

5、构课程设计typedefintKeyType;typedefstructNode{KeyTypekey;structNode*lchild,*rchild;}BSTNode,*BSTree;voidInsertBST(BSTree*bst,KeyTypekey){BSTrees;if(*bst==NULL)/*递归结束条件*/{s=newBSTNode;s->key=key;s->lchild=NULL;s->rchild=NULL;*bst=s;}elseif(key<(*bst)->key)In

6、sertBST(&((*bst)->lchild),key);/*将s插入左子树*/elseif(key>(*bst)->key)InsertBST(&((*bst)->rchild),key);/*将s插入右子树*/第12页共12页数据结构课程设计}voidCreateBST(BSTree*bst){KeyTypekey;*bst=NULL;scanf("%d",&key);while(key!=0){InsertBST(bst,key);scanf("%d",&key);}}voidInOrde

7、r(BSTreeroot){if(root!=NULL){InOrder(root->lchild);printf("%d",root->key);InOrder(root->rchild);}}BSTNode*DelBST(BSTreeT,KeyTypex){第12页共12页数据结构课程设计BSTNode*p,*f,*s,*q;p=T;f=NULL;while(p)/*查找关键字为x的待删结点p*/{if(p->key==x)break;f=p;/*f指向p结点的双亲结点*/if(p->key>x

8、)p=p->lchild;elsep=p->rchild;}if(p==NULL)returnT;/*若找不到,返回原来的二叉排序树*/if(p->lchild==NULL)/*p无左子树*/{if(f==NULL)T=p->rchild;elseif(f->lchild==p)f->lchild=p->rchild;elsef->rchild=p->rchild;第12页共12页数据结构课程设计deletep;}else/*p有左子树*/{q=p;s=p->lchi

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。