ImageVerifierCode 换一换
格式:DOCX , 页数:41 ,大小:484.40KB ,
资源ID:18282827      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/18282827.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(《数据结构》课程实验报告Word文档格式.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

《数据结构》课程实验报告Word文档格式.docx

1、主要思路是递归算法。时间复杂度为O(n)。1.3.9 Assign功能求指定元素的后一个元素的内容,传入头结点值、包含指定元素信息的一个临时表结点值、存储前一个元素的表结点地址。找到后,把新的数据值赋给所找到的节点。1.3.10 Parent功能找双亲节点,找到后输出1.3.11 LeftChild功能查找左孩子,利用递归的算法,与遍历的时间复杂度为相同O(n)1.3.12RightChild功能查找右孩子,利用递归的算法,与遍历的时间复杂度为相同O(n)1.3.13 LeftSibling功能查找节点的左边的堂兄弟的,找到后输出该节点的数据1.3.14 RightSibling功能查找节点的

2、右边的堂兄弟的,找到后输出该节点的数据1.3.15 InsertChild函数在二叉链表中插入新的节点1.3.15 DeleteChild功能删除指定编号的数据元素,传入头结点地址、编号i、表结点类型结构体地址来返回被删除元素内容。执行前先判断传入的编号是否在可寻找范围内。执行删除操作之后,进行“移位”运算。时间复杂度仍为O(n)。如下:1.3.16 PreOrderTraverse功能前序遍历二叉链表中的数据,采用先遍历左孩子,再访问根节点,后访问右孩子的思想来实现前序遍历的算法的。1.3.17 InOrderTraverse功能中序遍历的函数,对二叉链表的数据进行访问,并且利用PreOrd

3、erTraverse函数1.3.18 PostOrderTraverse功能采用后续遍历的思想,利用先序遍历的函数进行1.3.19 LevelOrderTraverse功能完全遍历二叉链表中的数据,并进行输出的1.3.20 Point功能定位节点的函数,在需要查找二叉链表二叉树的节点的时候,可以直接调用该函数,进行处理,相应的代码如下1.3.21 FILE * fileOpen功能读取功能,通过fscanf实现格式化读取,同时结合CreateList函数实现顺序1.3.22 BiTNode * Create(FILE *fp)功能把二叉链表二叉树的数据写入到文件中去1.4效率分析 在上面介绍各

4、功能时已经提到时间复杂度的计算了,这里再简单分析一下。具有同数量级复杂度的功能在实现方法上一般近似。比如InOrderTraverse,PostOrderTraverse,BiTreeDepth,LevelOrderTraverse它们都是基于PreOrderTraverse来设计的,所以效率都是O(n);而Root,Value,Assign,Parent,LeftChild,RightChild,LeftSiblingRightSibling,InsertChild,DeleteChild是基于VisitPoint,平均效率为O(n); InitTree DestroyBiTree所需信息,

5、所以效率为O(1);CreateBiTreeClearBiTreeBiTreeEmpty都要对二叉链表,平均效率为O(n)。实验总结与评价 我做了这个实验发现自己的编程能力很不好,自己的脑袋中有相应的想法和主意,但是因为自己的编程能力很不好也就实现不了自己的想法。 二叉链表的二叉树的时候,实现二叉链表线性的对我来说还可以实现,因为线性的所用到方法和技术,在学习十字链表的时候练习的比较少,实现起来难度是很大。特别是有了老师给的框架以后,我们要做的任务就是向里面填我们自己写的函数,在填写的过程中,我深深的感受到了,认真的重要性,因为我在写好调试的中发现了很多,因为自己的不小心和在敲代码的过程中的不

6、认真而造成的很不应该的错误,这些错误也给自己在调试的过程中也造成了很大的麻烦,因为是不认真而犯的错误,因此调试的过程中也很不好发现。对我来说,因为我的C语言的功底很不好,运用指针和链表的能力还没有能达到运用自如,理解深刻的地步,所以在顺序链表的链表的实现中,对我来说是一个很大的挑战,我有很多不会的地方通过自己看书,问室友和上网查询,一点一点的写了出来,肯定现在还是会有很多的问题,但是这也是我一直在努力把它做的更好,在调试的中出现了很多的BUG,自己一个个的慢慢的消除掉了,做出了,现在的程序。 如果问自己的体会,那一定是希望我自己以后多多的动手,把以前C语言的书好好再复习一遍,还有就是把现在正在

7、学习的数据结构的书上各个程序,自己要一个个的敲一遍,练习一下自己的熟悉程度。总的来说,我对这次的实验是很有感触的。因为,这次实验让我认识到了,自己的编程能力的低下,如果自己再不下一下功夫的话,那么数据结构的考试自己就十分的危险了。因此,我要加紧复习C语言的知识和数据结构学过的内容,争取自己能在接下来的学习中能有些进步。附录:参考书数据结构(C语言版)严蔚敏 吴伟民编著 C语言程序设计 曹计昌,李开编著 实验心得体会对于这两次的实验,我自己的体会是很深刻的,也是记忆深刻的。因为,正是因为这两次的实验深深地让我认识到了自己的水平是多么的低下,以前,自己还有点夜郎自大的认为,自己对所学的东西,自己掌

8、握的还差不多了呢。但是,经过这次的实验,我真的是清楚的发现自己对所学的知识的掌握还差的很多,自己还有很多的功课要补。第一,以前无论是学习C语言还是数据结构,我的方法是拿着书本看,还有就是拿着练习本写一写,而自己家上机的实践的时间是非常少的,因为我感觉上机得到的结构一定会和自己想的和写的一样呢,显然,我是错误的,因为在这次的实验里我就发现,即使是书上一模一样的代码,在机子上也是有很大 的可能出错的,更不用说是自己写的了,在写线性表,线性链表和二叉链表的时候,我出现了用书上的代码不能用的情况,而且是非常严重的错误。有些声明和指针的问题会出现很大的不同。我的体会是,从现在起,重视上机的过程,多书上的

9、程序一定要在机子上跑一下,然后再分析一下,出现这种结果的原因和整个程序的流程。第二,就是实验的 时候的规范的问题,由于,自己写代码没有很好的习惯和规则,于是,在自己写好的程序出现错误后自己不能够很快的 找到出现错误的位置,比如,对全局变量声明的时候,全局变量的位置问题,在结构和联合声明指针的时候,指针的形式和指针的命名的形式问题,这些错误都有在自己的实验的过程中出现,而且,也给自己带来了很大的麻烦。我的体会是,以后再写程序的时候一定遵守一定的规则和习惯,例如关键词的命名习惯,指针的使用形式和结构联合中的一些形式的问题,应该遵循一定的规则和习惯,因为,只有这样的自己在写好的调试和检查的过程中才不

10、会走那么多 的弯路,才会把做事的速度提高上去。 最后,就是自己的一些心得体会对这次的实验。做什么事情都要认真对待,无论事情的大小,因为只有这样自己才会养成认真做事的习惯,这次的数据结构的实验让我深深的意识到了这一点。实验三代码:#include stdio. = 0; FILE *pFile = fopen(fileName, r); 打开文件 fseek(pFile, 0, SEEK_END); 文件指针移到文件尾 nLen = ftell(pFile); 得到当前指针位置, 即是文件的长度 rewind(pFile); 文件指针恢复到文件头位置 动态申请空间, 为保存字符串结尾标志0, 多

11、申请一个字符的空间 m_pCharBuf = (char*)malloc(sizeof(char)* nLen + 1); if (!m_pCharBuf) perror(内存不够!n exit(0); 读取文件内容读取的长度和源文件长度有可能有出入,这里自动调整 nLen nLen = fread(m_pCharBuf, sizeof(char), nLen, pFile); m_pCharBufnLen = 0; 添加字符串结尾标志 printf(%sn, pchBuf); 把读取的内容输出到屏幕 fclose(pFile); 关闭文件 free(pchBuf); 释放空间 return

12、m_pCharBuf;写入排序完成后的结果void writeQuickSortResult(char *pResult) FILE *pFile = fopen(QuickSortResult.txt, w fputs(pResult, pFile); 写入数据typedef struct BiTNodeTElemType data;struct BiTNode *lchild,*rchild;BiTNode,*BiTree;typedef BiTree QElemType;typedef struct QNode QElemType data; struct QNode *next;QNo

13、de,*QueuePtr;typedef struct LinkQueue QueuePtr front,rear;LinkQueue;void InitTree(BiTree*T);void DestroyBiTree(BiTree *T);void CreateBiTree(BiTree *T);Status ClearBiTree(BiTree T);Status BiTreeEmpty(BiTree T);Status BiTreeDepth(BiTree T);Status Root(BiTree T);Status Value(BiTree T,TElemType e);Statu

14、s Assign(BiTree T,TElemType e,int value);Status Parent(BiTree T,TElemType e);Status LeftChild(BiTree T,TElemType e);Status RightChild(BiTree T,TElemType e);Status LeftSibling(BiTree T,TElemType e);Status RightSibling(BiTree T,TElemType e);Status InsertChild(BiTree T,int LR,BiTree C);Status DeleteChi

15、ld(BiTree T,int LR);Status PreOrderTraverse(BiTree T,Status(*Visit)(TElemType e);Status InOrderTraverse(BiTree T,Status(*Visit)(TElemType e);Status PostOrderTraverse(BiTree T,Status(*Visit)(TElemType e);Status LevelOrderTraverse(BiTree T,Status(*Visit)(TElemType e);Status Visit(TElemType e);BiTree P

16、oint(BiTree T,TElemType s); 返回二叉树中指向元素值为s的结点的指针void InitQueue(LinkQueue Q);构造一个空队列Status QueueEmpty(LinkQueue Q);判断队列是否为空void EnQueue(LinkQueue Q,QElemType e);插入元素为新的队尾元素Status DeQueue(LinkQueue Q,QElemType e);删除队头元素BiTNode * Create(FILE *fp);FILE * fileOpen();void main(void) int i; 文件内容读取出来 char *p

17、Text = openFileOnlyRead(resource.txt%snn, pText); BiTree T; FILE *p; TElemType e; int n; int value; int op=1; while(op) system(clsnn Menu for Linear Table On Sequence Structure n 1. InitTree 11. LeftChildn 2. DestroyBiTree 12. RightChildn 3. CreateBiTree 13. LeftSiblingn 4. ClearBiTree 14. RightSibl

18、ingn 5. BiTreeEmpty 15. InsertChildn 6. BiTreeDepth 16. DeleteChildn 7. Root 17. PreOrderTraversen 8. Value 18. InOrderTraversen 9. Assign 19. PostOrderTraversen 10. Parent 20. LevelOrderTraversen 0. Exitn 请选择你的操作020: scanf(%d,&op); switch(op) case 1: InitTree(&T); BiTNode * Create(p); FILE * fileOp

19、en(); if(!(T)=NULL)n-二叉树初始化成功!else printf(二叉树创建失败! getchar();getchar(); break; case 2:是否要销毁二叉树!(1为是,0是否)nn); if(n=1) DestroyBiTree(& else return 0; if(T!=NULL)n-二叉树成功销毁实现! elsen-DestroyList功能待实现 case 3:Please input the char:e=ne); CreateBiTree(T); if(T)!n-CreateBiTree功能实现! elsen-CreateBiTree功能待实现! c

20、ase 4: ClearBiTree(T); if(T)n-ClearBiTree功能待实现!n-ClearBiTree功能实现!0- case 5: BiTreeEmpty(T);n-BiTreeEmpty功能实现!n-BiTreeEmpty功能待实现! case 6: BiTreeDepth(T);n-BiTreeDepth功能实现!n-BiTreeDepth功能待实现! case 7: Root(T);n-Root功能实现!n-Root功能待实现! case 8:Please input the node of you want:%c Value(T,e); if(T=NULL)n-Va

21、lue功能实现!n-Value功能待实现! case 9:Please input the node and number of you want:e=nvalue=n%c%de,&value); Assign(T,e,value);n-Assign功能实现!n-Assign功能待实现! case 10: Parent(T,e);n-Parent功能实现!n-Parent功能待实现! case 11: LeftChild(T,e);n-LeftChild功能实现!n-LeftChild功能待实现n case 12: RightChild(T,e);n-RightChild功能实现nn-RightChild功能待实现! case 13: LeftSibling(T,e);n-LeftSibling功能实现!n-LeftSibling功能待实现n case 14: RightSibling(T,e);n-LeftSibling功能待实现! case 15:p,e,LR and C=n InsertChild(T,P,LR,C);线性表是空表! case 16: getchar()

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1