分治法实现一组无序序列的两路合并排序和快速排序.doc

分治法实现一组无序序列的两路合并排序和快速排序.doc

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
分治法实现一组无序序列的两路合并排序和快速排序

实 验 报 告 (2011/2012学年 第一学期) 课程名称 算法分析与设计A 实验名称 分治策略 实验时间 年 月 日 指导单位 计算机学院软件工程系 指导教师 学生姓名 班级学号 学院(系) 专 业 PAGE 8 实 验 报 告 实验名称 分治策略 指导教师 实验类型 验证 实验学时 2 实验时间 实验目的和任务 理解分治法的算法思想,阅读实现书上已有的部分程序代码并完善程序,加深对分治法的算法原理及实现过程的理解。 用分治法实现一组无序序列的两路合并排序和快速排序。要求清楚合并排序及快速排序的基本原理,编程实现分别用这两种方法将输入的一组无序序列排序为有序序列后输出。 实验环境(实验设备) VC++6.0 三、实验原理及内容(包括操作过程、结果分析等) 实验原理 1、排序是数据处理中常用的重要手段,是指将一个元素序列调整为按指定关键字值的递增(或递减)次序排列的有序序列。用分治法求解排序问题的思路是,按某种方式将序列分成两个或多个子序列,分别进行排序,再将已排序的子序列合并成一个有序序列。合并排序和快速排序是两种典型的符合分治策略的排序算法。 2、如果采用顺序存储的可排序表作为算法实现的数据结构,则需要定义一个可排序表类SortableList,两路合并算法和快速排序算法均由定义在该类上的函数实现。其中 Input函数和 Output函数分别用于向可排序表中输入待排序序列,以及输出已经 排序好的序列。 3、两路合并排序算法的基本思想是:将待排序元素平分成大小大致相同的两个子序列,然后对每个子序列分别使用递归的方法进行两路合并排序,直到子序列长度变为1,最后利用合并算法将得到的已排序好的两个子序列合并成一个有序的序列。 两路合并排序算法的核心部分是将子问题的解组合成原问题解得合并操作。常用的操作是新建一个序列,序列的大小等于要合并的两个子序列的长度之和。比较两个子序列中的最小值,输出其中较小者到新建的序列中,重复此过程直到其中一个子序列为空。如果另一个子序列中还有元素未输出,则将剩余元素依次输出到新建序列中即可。最终得到一个有序序列。 4、结合书上已有的程序代码,使用分治法的快速排序算法,实现对初始序列的排序。 快速排序算法的基本思想是: (1)在待排序序列 K[left:right]上选择一个基准元素(通常是最左边的元素 Kleft),通过一趟分划操作将序列分成左右两个子序列,左子序列中所有元素都小于等于该基准元素,有子序列中所有元素都大于等于该基准元素。 则当前基准元素所在的位置位于左、右子序列的中间,即是其排序完成后的最终位置。 (2)通过递归调用,对左子序列和右子序列再分别进行快速排序算法的调用。 (3)由于每一趟分划结束后,左子序列中的元素均不大于基准元素,右子序列中的元素均不小于基准元素。而每次分划后,对分划得到的左、右子序列的快速排序又均是就地进行,所以一旦左、右两个子序列都已分别排好序后,无需再执行任何计算,整个序列就是所要求的有序序列了。因此类中应定义成员函数 QuickSort来完成递归快速排序算法的调用和成员函数 5、比较合并排序和两种算法的异同。 问题分解过程: 合并排序——将序列一分为二即可。 (十分简单) 快速排序——需调用 Partition函数将一个序列划分为子序列。(分解方法相对较困难)子问题解合并得到原问题解的过程:合并排序——需要调用 Merge函数来实现。(Merge函数时间复杂度为O(n))..快速排序——一旦左、右两个子序列都已分别排序,整个序列便自然成为有序序列。(异常简单,几乎无须额外的工作,省去了从子问题解合并得到原问题解的过程) 基本程序 两路合并排序 #includeiostream.h class SortableList{ public: SortableList(int mSize){ maxSize=mSize; l=new int[maxSize]; n=0;} ~SortableList(){ delete []l;} void MergeSort(); void Input(); void Output(); private: int *l; int maxSize; int n; v

文档评论(0)

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

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

1亿VIP精品文档

相关文档