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

  1. 1、本文档共62页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构课程设计 引言 数据结构是一门理论性强、思维抽象、难度较大的课程,是基础课和专业课之间的桥梁。该课程的先行课程是计算机基础、程序设计语言、离散数学等,后续课程有操作系统、编译原理、数据库原理、软件工程等。 通过本门课程的学习,我们应该能透彻地理解各种数据对象的特点,学会数据的组织方法和实现方法,并进一步培养良好的程序设计能力和解决实际问题的能力。 数据结构是计算机科学与技术专业的一门核心专业基础课程,在该专业的课程体系中起着承上启下的作用,学好数据结构对于提高理论认知水平和实践能力有着极为重要的作用。学习数据结构的最终目的是为了获得求解问题的能力。对于现实世界中的问题,应该能从中抽象出一个适当的数学模型,该数学模型在计算机内部用相应的数据结构来表示,然后设计一个解此数学模型的算法,再进行编程调试,最后获得问题的解答。 实习课程是为了加强编程能力的培养,鼓励学生使用新兴的编程语言。相信通过数据结构课程实践,无论是理论知识,还是实践动手能力,我们都会有不同程度上的提高。 二、 课程设计目的 本课程是数据结构课程的实践环节。主要目的在于加强学生在课程中学习的相关算法和这些方法的具体应用,使学生进一步掌握在C++或其他语言中应用这些算法的能力。通过课程设计题目的练习,强化学生对所学知识的掌握及对问题分析和任务定义的理解。 三、内容设计要求 二叉排序树的实现: 用顺序和二叉链表作存储结构 1)以回车(‘\n’)为输入结束标志,输入数列L,生成一棵二叉排序树T; 2)对二叉排序树T作中序遍历,输出结果; 3)输入元素x,查找二叉排序树T,若存在含x的结点,则删除该结点,并作中序遍历(执行操作2);否则输出信息“无x”。 (一)问题分析和任务定义 对问题的描述应避开具体的算法和涉及的数据结构,它是对要完成的任务作出明确的回答,强调的是做什么,而不是怎么做。 (二)详细的设计和编码 算法的具体描述和代码的书写。 (三)上机调试 源程序的输入和代码的调试。 要求:设计中要求综合运用所学知识,上机解决一些与实际应用结合紧密的、规模较大的问题,通过分析、设计、编码、调试等各环节的训练,深刻理解、牢固的掌握数据结构和算法设计技术,掌握分析、解决实际问题的能力。 四、源代码 1、用二叉链表存储结构实现 #include iostream using namespace std; typedef int KeyType; typedef struct Node{ KeyType key ; struct Node *lchild,*rchild; }BSTNode, *BSTree; void InsertBST(BSTree *bst, KeyType key){ BSTree s; if (*bst == NULL)/*递归结束条件*/ { s=new BSTNode; s- key=key; s-lchild=NULL; s-rchild=NULL; *bst=s; } else if (key (*bst)-key) InsertBST(((*bst)-lchild), key);/*将s插入左子树*/ else if (key (*bst)-key) InsertBST(((*bst)-rchild), key); /*将s插入右子树*/ } void CreateBST(BSTree *bst){ KeyType key; *bst=NULL; scanf(%d, key); while (key!=0) { InsertBST(bst, key); scanf(%d, key); } } void InOrder(BSTree root) { if (root!=NULL) { InOrder(root-lchild); printf(%d ,root-key); InOrder(root-rchild); } } BSTNode * DelBST(BSTree T, KeyType x) { BSTNode *p, *f,*s ,*q; p=T; f=NULL; while(p) /*查找关键字为x的待删结点p*/ { if(p-key==x) break; f=p; /*f指向p结点的双亲结点*/ if(p-keyx) p=p-lchild; else p=p-rchild; } if(p==NULL)return T; /*若找不到,返回原来的二叉排序树*/ if(p-lchild==NU

您可能关注的文档

文档评论(0)

seunk + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档