数据结构c语言版实验报告

数据结构c语言版实验报告

ID:19410466

大小:540.00 KB

页数:9页

时间:2018-10-02

数据结构c语言版实验报告_第1页
数据结构c语言版实验报告_第2页
数据结构c语言版实验报告_第3页
数据结构c语言版实验报告_第4页
数据结构c语言版实验报告_第5页
资源描述:

《数据结构c语言版实验报告》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、苏州科技学院数据结构(C语言版)实验报告专业班级测绘0911学号0920115130姓名朱辉实习地点C1-203指导教师史守正实验四图一、程序设计的基本思想,原理和算法描述:图是一种较线性表和树更加复杂的一种数据结构,在图形结构中,结点之间的关系可以是任意的,图中任意两个数据元素之间都可能相关,图主要有无向图,有向图等(1)建立无向网的邻接矩阵存储并输出,参考程序清单,实现无向图的邻接矩阵表示。(2)建立图的邻接表存储并在此基础上实现图的深度优先遍历和广度优先遍历备注:无向图已完成,无向网需要自己建立(参照算法7.2);参照算法7.4,7.5,7

2、.6完成图的深度遍历,广度遍历;请添加适当的注释。二、源程序及注释(打包上传):三、运行输出结果:四、调试和运行程序过程中产生的问题及采取的措施:在程序编辑的过程中,有许多地方出现不能顺序运行的,还有代码出现遗漏出错,图的遍历是重点但因为知识的残缺不能完整的编译出来,又或者编译的程序不能正确的得到结果,再通过多人合作共同讨论后得到了满意的解决。五、对算法的程序的讨论、分析,改进设想,其它经验教训:经过这次这么复杂的程序实验,我终于发现了调用函数的巨大优越性,以前遇到都是很短的程序,感觉调用有点多余,但复杂的程序时,如果不采用调用的话,会使程序非常

3、的乱,改程序时不知道从哪改,调用函数能够更好使程序简洁话,层次话,更加容易让人看懂这次试验的逻辑性给了我们很大启发通过本次实验让我对图有了更深刻的认识,再通过多次的更改后终于将实验做出来,在实验中也出现了许多问题,有不出结果,有不能运行的,但最终只要努力都会搞定的实验五查找一、程序设计的基本思想,原理和算法描述:实现二叉排序树上的查找、插入、删除算法。具体实现要求:1.用二叉链表做存储结构,输入键值序列,利用查找、插入算法建立一棵二叉排序树。2.按中序遍历这棵二叉排序树。3.在二叉排序树上插入结点。4.删除二叉排序树上的结点。二、源程序及注释(打

4、包上传):三、运行输出结果:四、调试和运行程序过程中产生的问题及采取的措施:查找是一种常用到的方法在程序中十分常见,在程序运行中。由于对遍历了解的不深刻不能够完全领悟其中的运行原理,所以出现没有结果输出的现象。在书中不断的了解分析下从而得到了解决,书本的知识很有作用。五、对算法的程序的讨论、分析,改进设想,其它经验教训:经过这次这么复杂的程序实验,我终于发现了调用函数的巨大优越性,以前遇到都是很短的程序,感觉调用有点多余,但复杂的程序时,如果不采用调用的话,会使程序非常的乱,改程序时不知道从哪改,调用函数能够更好使程序简洁话,层次话,更加容易让人

5、看懂这次试验的逻辑性给了我们很大启发,在程序不断复杂的今天只有很好了解程序的过程,把握程序中心思想才能够更好的完善研发程序,在不断的累积中达到更高的层次。实验六排序一、程序设计的基本思想,原理和算法描述排序是计算机程序设计中的一种重要操作。它的主要思想是将一个数据元素的任意序列,比较多种排序的优劣主要是看它排序的效率。重新排列成一个按关键字有序的序列,编写主函数,分别实现直接插入、冒泡排序(算法在P16)、快速排序、简单选择排序、堆排序等排序算法。(1)直接插入排序:是一种最简单的排序,是将一个记录插入到已排好序的初始排列中冒泡排序;依次比较相邻

6、的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后。在第二趟:仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到倒数第二个数(倒数第一的位置上已经是最大的),第二趟结束,在倒数第二的位置上得到一个新的最大数(其实在整个数列中是第二大的数)。如此下去,重复以上过程,直至最终完成排序。  由于

7、在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。  用二重循环实现,外循环变量设为i,内循环变量设为j。外循环重复9次,内循环依次重复9,8,...,1次。每次进行比较的两个元素都是与内循环j有关的,它们可以分别用a[j]和a[j+1]标识,i的值依次为1,2,...,9,对于每一个i,j的值依次为1,2,...10-i。二、源程序及注释(打包上传):三、运行输出结果:四、调试和运行程序过程中产生的问题及采取的措施:刚开始看到程序,太长,一点也看不懂它的意思,无从下手的感觉,这是就要考验人的耐心,慢慢看,结合书里所讲的

8、知识,终于理解整个程序,还有递归的使用,要注意,初始时的状态以及如何使用递归,注意普遍性,思考时从普通的开始。五、对算法的程序的讨论、分

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

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

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