河南城建学院课程设计报告书专业:计算机科学与技术课程设计名称:《数据结构课程设计》题目:用顺序和二叉链表作存储结构班级:0814101班学号:081410150姓名:周朋同组人员:曹路锋指导老师:张延红张芳芳杨斌完成时间:2012年2月16日星期四摘要数据结构是一门理论性强、思维抽象、难度较大的课程,是基础课和专业课之间的桥梁。
该课程的先行课程是计算机基础、程序设计语言、离散数学等,后续课程有操作系统、编译原理、数据库原理、软件工程等。
通过本门课程的学习,我们应该能透彻地理解各种数据对象的特点,学会数据的组织方法和实现方法,并进一步培养良好的程序设计能力和解决实际问题的能力。
数据结构是计算机科学与技术专业的一门核心专业基础课程,在该专业的课程体系中起着承上启下的作用,学好数据结构对于提高理论认知水平和实践能力有着极为重要的作用。
学习数据结构的最终目的是为了获得求解问题的能力。
对于现实世界中的问题,应该能从中抽象出一个适当的数学模型,该数学模型在计算机内部用相应的数据结构来表示,然后设计一个解此数学模型的算法,再进行编程调试,最后获得问题的解答。
实习课程是为了加强编程能力的培养,鼓励学生使用新兴的编程语言。
相信通过数据结构课程实践,无论是理论知识,还是实践动手能力,我们都会有不同程度上的提高。
目录目录 (1)第一章课程设计目的........................................................................ 错误!未定义书签。
第二章内容设计要求 (1)2.1问题分析和任务定义.......................................................................... 错误!未定义书签。
2.2详细的设计和编码 .............................................................................. 错误!未定义书签。
2.3上机调试 ................................................................................................ 错误!未定义书签。
第三章源代码.................................................................................... 错误!未定义书签。
3.1用二叉链表存储结构实现3.2用顺序存储结构实现 (7)第四章测试分析 ............................................................................... 错误!未定义书签。
4.1用二叉链表存储结构实现 (10)4.2用顺序存储结构实现 (11)总结 (11)心得体会 (11)参考文献 (12)第一章课程设计目的本课程是数据结构课程的实践环节。
主要目的在于加强学生在课程中学习的相关算法和这些方法的具体应用,使学生进一步掌握在C++或其他语言中应用这些算法的能力。
通过课程设计题目的练习,强化学生对所学知识的掌握及对问题分析和任务定义的理解。
第二章内容设计要求二叉排序树的实现:用顺序和二叉链表作存储结构1)以回车(…\n‟)为输入结束标志,输入数列L,生成一棵二叉排序树T;2)对二叉排序树T作中序遍历,输出结果;3)输入元素x,查找二叉排序树T,若存在含x的结点,则删除该结点,并作中序遍历(执行操作2);否则输出信息“无x”。
2.1 问题分析和任务定义对问题的描述应避开具体的算法和涉及的数据结构,它是对要完成的任务作出明确的回答,强调的是做什么,而不是怎么做。
2.2 详细的设计和编码算法的具体描述和代码的书写。
2.3 上机调试源程序的输入和代码的调试。
要求:设计中要求综合运用所学知识,上机解决一些与实际应用结合紧密的、规模较大的问题,通过分析、设计、编码、调试等各环节的训练,深刻理解、牢固的掌握数据结构和算法设计技术,掌握分析、解决实际问题的能力。
第三章源代码3.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;}elseif (key < (*bst)->key)InsertBST(&((*bst)->lchild), key);/*将s插入左子树*/ elseif (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->key>x)p=p->lchild;elsep=p->rchild;}if(p==NULL)return T; /*若找不到,返回原来的二叉排序树*/ if(p->lchild==NULL) /*p无左子树*/{if(f==NULL)T=p->rchild;elseif(f->lchild==p)f->lchild=p->rchild ;elsef->rchild=p->rchild ;delete p;}else /*p有左子树*/{q=p;s=p->lchild;while(s->rchild) /*在p的左子树中查找最右下结点*/{q=s;s=s->rchild;}if(q==p)q->lchild=s->lchild ; /*将s的左子树链到q上*/ elseq->rchild=s->lchild;p->key=s->key;delete s;}return T;}void main(){BSTree T;int x;BSTree result;printf("建立二叉排序树,请输入序列L:\n");CreateBST(&T);printf("中序遍历输出序列为:");InOrder(T);cin>>x;result = DelBST(T,x);if (result != NULL){InOrder(result);}elseprintf("无x\n");}3.2 用顺序存储结构实现#include<iostream>using namespace std;typedef int KeyType;typedef struct Node{KeyType key;struct Node *next;}BSTNode,*BSTree;int A[40]={-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1}; int j,i=0;void InsertBST(int A[],KeyType key){int j=0;while(A[j]!=-1){if(key<A[j])j=2*j+1;elsej=2*j+2;}A[j]=key;}void CreateBST(int A[]){ int key;scanf("%d", &key); while (key!=-1){InsertBST(A,key);scanf("%d", &key);}}void Traverse(int A[],int i){ if(A[i]!=-1){Traverse(A,2*i+1);cout<<A[i]<<'\t';Traverse(A,2*i+2);}}void DelBST(int A[],KeyType x){for(i=0;i<40;i++)if(A[i]==x)A[i]=-1;}void main(){int x;//int key;printf("建立二叉排序树,请输入序列L:\n");CreateBST(A);printf("中序遍历输出序列为:");Traverse(A,0);cin>>x;if(A[i]!=-1){DelBST(A,x);printf("删除x后中序遍历输出序列为:");Traverse(A,0);}elseprintf("无X\n");}第四章测试分析4.1 用二叉链表存储结构实现:4.2 用顺序存储结构实现:总结在今后的工作、学习中我将认真总结经验教训,努力使自己成为一名技术过硬、工作严谨、思维活跃的工程人员,为提高人们的生活质量做出更大的贡献心得体会通过一周的课程设计,对计算机的应用,数据结构的作用以及C++的使用都有了更深的了解。