实验四排序实验报告(共25页).doc
《实验四排序实验报告(共25页).doc》由会员分享,可在线阅读,更多相关《实验四排序实验报告(共25页).doc(24页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上数据结构实验报告实验名称:实验四 排序学生姓名:班级:班内序号:学号:日期:2012年12月21日1、 实验要求题目2使用链表实现下面各种排序算法,并进行比较。排序算法:1、插入排序2、冒泡排序3、快速排序4、简单选择排序5、其他要求:1、测试数据分成三类:正序、逆序、随机数据。2、对于这三类数据,比较上述排序算法中关键字的比较次数和移动次数(其中关键字交换计为3次移动)。 3、对于这三类数据,比较上述排序算法中不同算法的执行时间,精确到微秒(选作)。4、对2和3的结果进行分析,验证上述各种算法的时间复杂度。编写测试main()函数测试线性表的正确性。2、 程序分析2
2、.1存储结构 说明:本程序排序序列的存储由链表来完成。 其存储结构如下图所示。(1)单链表存储结构:结点 地址:1000HA21080H头指针地址:1020HA0 10C0H 地址:1080H A3NULL地址:10C0HA11000H(2)结点结构struct Nodeint data;Node * next;示意图:int dataNode * next2.2关键算法分析一:关键算法 (一)直接插入排序 void LinkSort:InsertSort()直接插入排序是插入排序中最简单的排序方法,其基本思想是:依次将待排序序列中的每一个记录插入到一个已排好的序列中,直到全部记录都排好序。(
3、1)算法自然语言1.将整个待排序的记录序列划分成有序区和无序区,初始时有序区为待排序记录序列中的第一个记录,无序区包括所有剩余待排序的记录;2.将无须去的第一个记录插入到有序区的合适位置中,从而使无序区减少一个记录,有序区增加一个记录;3.重复执行2,直到无序区中没有记录为止。(2)源代码void LinkSort:InsertSort() /从第二个元素开始,寻找前面那个比它大的Node * P = front-next; /要插入的节点的前驱while(P-next)Node * S = front; /用来比较的节点的前驱while(1)CompareCount+;if( P-next-
4、data next-data )/ P的后继比S的后继小则插入 insert(P, S); break; S = S-next;if(S=P)/若一趟比较结束,且不需要插入 P = P-next; break; (3)时间和空间复杂度最好情况下,待排序序列为正序,时间复杂度为O(n)。最坏情况下,待排序序列为逆序,时间复杂度为O(n2)。直接插入排序只需要一个记录的辅助空间,用来作为待插入记录的暂存单元和查找记录的插入位置过程中的“哨兵”。直接插入排序是一种稳定的排序方法。直接插入排序算法简单容易实现,当序列中的记录基本有序或带排序记录较少时,他是最佳的排序方法。但当待排序的记录个数较多时,大
5、量的比较和移动操作使直接插入排序算法的效率减低。(二)冒泡排序 void LinkSort:BubbleSort()冒泡排序是交换排序中最简单的排序方法,其基本思想是:两两比较相邻记录的关键码,如果反序则交换,直到没有反序的记录为止。本程序采用改进的冒泡程序。(1)算法自然语言1.将整个待排序的记录序列划分成有序区和无序区,初始状态有序区为空,无序区包括所有待排序的记录。2.对无序区从前向后依次将相邻记录的关键码进行比较,若反序则交换,从而使得关键码小的记录向前移,关键码大的记录向后移(像水中的气泡,体积大的先浮上来)。3.将最后一次交换的位置pos,做为下一趟无序区的末尾。4.重复执行2和3
6、,直到无序区中没有反序的记录。(2)源代码void LinkSort:BubbleSort()Node * P = front-next;while(P-next) /第一趟排序并查找无序范围CompareCount+;if( P-data P-next-data)swap(P, P-next);P = P-next;Node * pos = P;P = front-next;while(pos != front-next)Node * bound = pos;pos = front-next;while(P-next != bound)CompareCount+;if( P-data P-n
7、ext-data) swap(P, P-next); pos = P-next;P = P-next;P = front-next;(3)时间和空间复杂度在最好情况下,待排序记录序列为正序,算法只执行了一趟,进行了n-1次关键码的比较,不需要移动记录,时间复杂度为O(n);在最坏情况下,待排序记录序列为反序,时间复杂度为O(n2),空间复杂度为O(1)。冒泡排序是一种稳定的排序方法。初始键值序列 50 13 55 97 27 38 49 65第一趟排序结果 13 50 55 27 38 49 65 97第二趟排序结果 13 50 27 38 49 55 65 97第三趟排序结果 13 27 3
8、8 49 50 55 65 97第四趟排序结果 13 27 38 49 50 55 65 97 冒泡排序过程(三)快速排序 void LinkSort:Qsort()(1)算法自然语言1.首先选一个轴值(即比较的基准),将待排序记录分割成独立的两部分,左侧记录的关键码均小于或等于轴值,右侧记录的关键码均大于或等于轴值。2.然后分别对这两部分重复上述过程,直到整个序列有序。3.整个快速排序的过程递归进行。(2)源代码void LinkSort:Qsort()Node * End = front;while(End-next) End = End-next;Partion(front, End);
9、void LinkSort:Partion(Node * Start, Node * End)if(Start-next=End | Start=End)/递归返回return ;Node * Mid = Start; /基准值前驱Node * P = Mid-next;while(P!=End & P!=End-next)CompareCount+;if( Mid-next-data P-next-data )/元素值小于轴点值,则将该元素插在轴点之前 if( P-next = End )/若该元素为End,则将其前驱设为EndEnd = P;insert(P, Mid); Mid = Mi
10、d-next; else P = P-next;Partion(Start, Mid); /递归处理基准值左侧链表Partion(Mid-next, End); /递归处理基准值右侧链表(3)时间和空间复杂度在最好的情况下,时间复杂度为O(nlog2n)。在最坏的情况下,时间复杂度为O(n2)。快速排序是一种不稳定的排序方法。(四)简单选择排序基本思想为:第i趟排序通过n-i次关键码的比较,在n-i+1(1in-1)各记录中选取关键码最小的记录,并和第i个记录交换作为有序序列的第i个记录。(1)算法自然语言1.将整个记录序列划分为有序区和无序区,初始状态有序区为空,无序区含有待排序的所有记录。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 排序 报告 25
限制150内